Skip to content

Commit

Permalink
clayconfig docs (#108)
Browse files Browse the repository at this point in the history
* adding readme docs

* small tweaks

* small tweak
  • Loading branch information
jonwinton authored Nov 5, 2018
1 parent 0fc4106 commit 94e0798
Showing 1 changed file with 42 additions and 1 deletion.
43 changes: 42 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -268,7 +268,7 @@ body:
must:
-
terms:
siteSlug:
siteSlug:
- intelligencer # show only pages for a specific site
-
match:
Expand Down Expand Up @@ -360,6 +360,8 @@ Compile assets based on standardized Clay conventions. Assets are compiled to a

Specifying `--watch` on `claycli compile` or any of its subcommands will compile assets once, then watch source files (and their dependencies) for changes. Specifying `--minify` (or setting `CLAYCLI_COMPILE_MINIFIED`) will run assets through minification and bundling if applicable. The `CLAYCLI_COMPILE_ASSET_HOST` and `CLAYCLI_COMPILE_ASSET_PATH` variables are used by the `styles` and `fonts` subcommands to generate links to media and font files in the compiled CSS.

A project specific clay config file is also supported, [read more here](https://github.com/clay/claycli#project-specific-config-file).

#### Arguments

* `-w, --watch` enables watching of source files after compilation
Expand Down Expand Up @@ -650,6 +652,45 @@ clay compile scripts --minify
clay compile scripts --globs 'global/js/!(*.test).js'
```

### Project Specific Config File

Not all projects are the same, and for project specific compilation changes you can add a `claycli.config.js` file to your project's root. This file must simply export an Object whose contains key/value pairs are read during compilation. Good use cases for this file include:

* Adding PostCSS plugins to [`styles`](https://github.com/clay/claycli#styles) compilation
* Updating options passed into Autoprefixer
* Changing Babel browser target to meet your env support requirements

#### Arguments

The `claycli.config.js` file currently supports the following arguments:

* `plugins` (_Array_): list of PostCSS plugins that will be concatenated to the end of the list already supported by the `styles` compilation command
* `babelTargets` (_String|Array_): the value of this property is passed to the [Babel `targets` option](https://babeljs.io/docs/en/babel-preset-env#targets) to describe the environments your compiled scripts support
* `autoprefixerOptions` (_Object_): an Object which is [passed directly to `autoprefixer`](https://www.npmjs.com/package/autoprefixer#options) for style and Kiln plugin compilation

#### Example

```js
'use strict';
module.exports = {
plugins: [
require('postcss-functions')({
functions: {
em: function (pixels, browserContext) {
var browserContext = parseInt(browserContext, 10) || 16,
pixels = parseFloat(pixels);
return pixels / browserContext + 'em';
}
}
})
],
babelTargets: '> 0.25%, not dead',
autoprefixerOptions: { browsers: ['last 2 versions', 'ie >= 9', 'ios >= 7', 'android >= 4.4.2'] }
};
```

# Programmatic API

The core `claycli` functionality is exposed as an api, allowing you to use it in Node.js. All main commands are properties of the exported `claycli` object.
Expand Down

0 comments on commit 94e0798

Please sign in to comment.