Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feat(dictionary) Added new filter removePrivate #770

Merged
merged 9 commits into from
Feb 15, 2022
50 changes: 50 additions & 0 deletions __tests__/common/filters.test.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
/*
* Copyright 2017 Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
* the License. A copy of the License is located at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
* CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions
* and limitations under the License.
*/

var filters = require('../../lib/common/filters');

describe('common', () => {
describe('filters', () => {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you for adding unit tests!

describe('removePrivate', () => {
it('should keep a regular token in for distribution', () => {
var regularToken = {
name: 'color-border',
value: '#1a1aed'
}

expect(filters["removePrivate"](regularToken)).toEqual(true);
});

it('should keep an unfiltered token in for distribution', () => {
var unfilteredToken = {
name: 'color-border',
value: '#1a1aed',
private: false
}

expect(filters["removePrivate"](unfilteredToken)).toEqual(true);
});


it('should remove a filtered token from the distribution output', () => {
var filteredToken = {
name: 'color-border',
value: '#1a1aed',
private: true
}

expect(filters["removePrivate"](filteredToken)).toEqual(false);
});
});
});
});
2 changes: 2 additions & 0 deletions examples/advanced/filters/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
build/
node_modules/
99 changes: 99 additions & 0 deletions examples/advanced/filters/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,99 @@
## Filters
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you for adding an example!


This example shows how to use built-in and custom filters to the design tokens.

Filters are functions that might remove according to some conditions a design token from the output distribution.

#### Running the example

First of all, set up the required dependencies running the command `npm install` in your local CLI environment (if you prefer to use *yarn* update the commands accordingly).

At this point, if you want to build the tokens you can run `npm run build`. This command will generate the files in the `build` folder.

#### How does it work a built-in filter?

Currently StyleDictionary supports just the following built-in filters:

- removePrivate

You have to apply it in the `config.json` file:

```
"scss": {
"buildPath": "build/web/",
"files": [{
"destination": "colors.scss",
"filter": "removePrivate",
"format": "scss/variables"
}]
}
```

The StyleDictionary will take care of filtering out proper design tokens from the source of truth:

```
{
"color": {
"gray": {
"light" : {
"value": "#CCCCCC",
"group": "color",
"private": true
},
"medium": {
"value": "#999999",
"group": "color"
},
"dark" : {
"value": "#111111",
"group": "color"
}
},
}
}
```

#### How does it work a custom filter?

To declare a custom **filter**, you have to call the `registerFilter` method:

```
StyleDictionary.registerFilter({
name: 'isTextTransform',
matcher: function(token) {
return token.attributes.category === 'font' && token.value.includes['lowercase', 'uppercase]
}
});
```

You have to apply it in the `config.json` file:

```
"scss": {
"buildPath": "build/web/",
"files": [{
"destination": "fonts.scss",
"filter": "isTextTransform",
"format": "scss/variables"
}]
}
```

The StyleDictionary will take care of filtering out proper design tokens from the source of truth:

```
{
"fonts": {
"title-transform": {
"value": "uppercase", // included
"group": "font"
},
"title-size": {
"value": "36px", // excluded
"group": "font"
}
}
}
```

More information can be found on the [documentation](https://amzn.github.io/style-dictionary/#/api?id=registerfilter).
32 changes: 32 additions & 0 deletions examples/advanced/filters/build.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
const StyleDictionary = require('../../../index');
silversonicaxel marked this conversation as resolved.
Show resolved Hide resolved

console.log('Build started...');
console.log('\n==============================================');


// REGISTER THE CUSTOM TRANFORMS

StyleDictionary.registerTransform({
name: 'hexRGB/hexARGB',
type: 'value',
matcher: function(token) {
return token.group === 'color';
},
transformer: function(token) {
// for sake of simplicity, in this example we assume colors are always in the format #xxxxxx
return token.value.replace(/^#/,'#FF');
}
});

// APPLY THE CONFIGURATION
// IMPORTANT: the registration of custom transforms
// needs to be done _before_ applying the configuration
const StyleDictionaryExtended = StyleDictionary.extend(__dirname + '/config.json');


// FINALLY, BUILD ALL THE PLATFORMS
StyleDictionaryExtended.buildAllPlatforms();


console.log('\n==============================================');
console.log('\nBuild completed!');
21 changes: 21 additions & 0 deletions examples/advanced/filters/config.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
{
"source": ["tokens/**/*.json"],
"platforms": {
"web": {
"buildPath": "build/web/",
"files": [{
"destination": "tokens.js",
"filter": "removePrivate",
"format": "javascript/es6"
}]
},
"scss": {
"buildPath": "build/web/",
"files": [{
"destination": "tokens.scss",
"filter": "removePrivate",
"format": "scss/variables"
}]
}
}
}
Loading