From fb883d0d301ee39b3e963254a09e4d9a4069f5ed Mon Sep 17 00:00:00 2001 From: Danny Banks Date: Wed, 24 Jul 2019 10:10:37 -0700 Subject: [PATCH 1/2] docs(format): add info about filtering and format configuration --- docs/formats.md | 49 +++++++++++++++++++++++- scripts/handlebars/templates/formats.hbs | 49 +++++++++++++++++++++++- 2 files changed, 96 insertions(+), 2 deletions(-) diff --git a/docs/formats.md b/docs/formats.md index 2609bf5ba..9a8ab05c4 100644 --- a/docs/formats.md +++ b/docs/formats.md @@ -31,10 +31,57 @@ You use formats in your config file under platforms > [platform] > files > [file There is an extensive (but not exhaustive) list of [included formats](#pre-defined-formats) available in Style Dictionary. +### Format configuration + +Formats are can take configuration to make them more flexible. This allows you to re-use the same format multiple times with different configuration or to allow the format to use data not defined in the tokens themselves. To configure a format add extra attributes on the file object in your configuration like so: + +```json +{ + "source": ["propperties/**/*.json"], + "platforms": { + "scss": { + "transformGroup": "scss", + "files": [{ + "destination": "map.scss", + "format": "scss/map-deep", + "mapName": "my-tokens" + }] + } + } +} +``` + +In this example we are adding the `mapName` configuration to the `scss/map-deep` format. This will change the name of the SCSS map in the output. Not all formats have the configuration options; format configuration is defined by the format itself. To see the configurtion options of a format, take a look at the documentation of the [specific format](#pre-defined-formats) + +### Filtering tokens + +A special file configuration is `filter`, which will filter the tokens before they get to the format. This allows you to re-use the same format to generate multiple files with different sets of tokens. Filtering tokens works by adding a `filter` attribute on the file object, where `filter` is: + +* An object which gets passed to [Lodash's filter method](https://lodash.com/docs/4.17.14#filter). +* A string that references the name of a registered filter, using the [`registerFilter`](api.md#registerfilter) method +* A function if you are defining your configuration in Javascript rather than JSON. The filter function takes a token as the property and should return a boolean if the token should be included (true) or excluded (false). + +```javascript +{ + "destination": "destination", + "format": "myCustomFormat", + "filter": "myCustomFilter", // a named filter defined with .registerFilter + "filter": function(token) {}, // an inline function + "filter": {} // an object pass to lodash's filter method +} +``` ### Creating formats -You can create custom formats using the [`registerFormat`](api.md#registerformat) function. +You can create custom formats using the [`registerFormat`](api.md#registerformat) function. If you want to add configuration to your custom format, `this` is bound to the file object so you can access attributes on the file object with `this.myCustomAttribute` if the file object looks like: + +```json +{ + "destination": "destination", + "format": "myCustomFormat", + "myCustomAttribute": "Hello world" +} +``` ### Using a template / templating engine to create a format diff --git a/scripts/handlebars/templates/formats.hbs b/scripts/handlebars/templates/formats.hbs index 1c862f956..6d2f6e581 100644 --- a/scripts/handlebars/templates/formats.hbs +++ b/scripts/handlebars/templates/formats.hbs @@ -27,10 +27,57 @@ You use formats in your config file under platforms > [platform] > files > [file There is an extensive (but not exhaustive) list of [included formats](#pre-defined-formats) available in Style Dictionary. +### Format configuration + +Formats are can take configuration to make them more flexible. This allows you to re-use the same format multiple times with different configuration or to allow the format to use data not defined in the tokens themselves. To configure a format add extra attributes on the file object in your configuration like so: + +```json +{ + "source": ["propperties/**/*.json"], + "platforms": { + "scss": { + "transformGroup": "scss", + "files": [{ + "destination": "map.scss", + "format": "scss/map-deep", + "mapName": "my-tokens" + }] + } + } +} +``` + +In this example we are adding the `mapName` configuration to the `scss/map-deep` format. This will change the name of the SCSS map in the output. Not all formats have the configuration options; format configuration is defined by the format itself. To see the configurtion options of a format, take a look at the documentation of the [specific format](#pre-defined-formats) + +### Filtering tokens + +A special file configuration is `filter`, which will filter the tokens before they get to the format. This allows you to re-use the same format to generate multiple files with different sets of tokens. Filtering tokens works by adding a `filter` attribute on the file object, where `filter` is: + +* An object which gets passed to [Lodash's filter method](https://lodash.com/docs/4.17.14#filter). +* A string that references the name of a registered filter, using the [`registerFilter`](api.md#registerfilter) method +* A function if you are defining your configuration in Javascript rather than JSON. The filter function takes a token as the property and should return a boolean if the token should be included (true) or excluded (false). + +```javascript +{ + "destination": "destination", + "format": "myCustomFormat", + "filter": "myCustomFilter", // a named filter defined with .registerFilter + "filter": function(token) {}, // an inline function + "filter": {} // an object pass to lodash's filter method +} +``` ### Creating formats -You can create custom formats using the [`registerFormat`](api.md#registerformat) function. +You can create custom formats using the [`registerFormat`](api.md#registerformat) function. If you want to add configuration to your custom format, `this` is bound to the file object so you can access attributes on the file object with `this.myCustomAttribute` if the file object looks like: + +```json +{ + "destination": "destination", + "format": "myCustomFormat", + "myCustomAttribute": "Hello world" +} +``` ### Using a template / templating engine to create a format From e577999dcb1b7c9af4db336bce1f315420efe1a4 Mon Sep 17 00:00:00 2001 From: Danny Banks Date: Wed, 14 Aug 2019 10:42:29 -0700 Subject: [PATCH 2/2] docs(format): fixing typo in formats --- docs/formats.md | 2 +- scripts/handlebars/templates/formats.hbs | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/docs/formats.md b/docs/formats.md index 9a8ab05c4..6788bee58 100644 --- a/docs/formats.md +++ b/docs/formats.md @@ -33,7 +33,7 @@ There is an extensive (but not exhaustive) list of [included formats](#pre-defin ### Format configuration -Formats are can take configuration to make them more flexible. This allows you to re-use the same format multiple times with different configuration or to allow the format to use data not defined in the tokens themselves. To configure a format add extra attributes on the file object in your configuration like so: +Formats can take configuration to make them more flexible. This allows you to re-use the same format multiple times with different configuration or to allow the format to use data not defined in the tokens themselves. To configure a format add extra attributes on the file object in your configuration like so: ```json { diff --git a/scripts/handlebars/templates/formats.hbs b/scripts/handlebars/templates/formats.hbs index 6d2f6e581..5a41888e6 100644 --- a/scripts/handlebars/templates/formats.hbs +++ b/scripts/handlebars/templates/formats.hbs @@ -29,7 +29,7 @@ There is an extensive (but not exhaustive) list of [included formats](#pre-defin ### Format configuration -Formats are can take configuration to make them more flexible. This allows you to re-use the same format multiple times with different configuration or to allow the format to use data not defined in the tokens themselves. To configure a format add extra attributes on the file object in your configuration like so: +Formats can take configuration to make them more flexible. This allows you to re-use the same format multiple times with different configuration or to allow the format to use data not defined in the tokens themselves. To configure a format add extra attributes on the file object in your configuration like so: ```json {