From 232e878c7406fa016fea46611fab0603348ab5e6 Mon Sep 17 00:00:00 2001 From: Alessandro Rabitti Date: Tue, 1 Feb 2022 19:25:38 +0100 Subject: [PATCH 1/8] feat(dictionary): added filter removePrivate --- __tests__/common/filters.test.js | 50 ++++++++++++++++++++++++++++++++ index.js | 2 +- lib/common/filters.js | 30 +++++++++++++++++++ 3 files changed, 81 insertions(+), 1 deletion(-) create mode 100644 __tests__/common/filters.test.js create mode 100644 lib/common/filters.js diff --git a/__tests__/common/filters.test.js b/__tests__/common/filters.test.js new file mode 100644 index 000000000..5ea6f24d9 --- /dev/null +++ b/__tests__/common/filters.test.js @@ -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', () => { + 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); + }); + }); + }); +}); diff --git a/index.js b/index.js index 78ef25fd9..536443c2d 100644 --- a/index.js +++ b/index.js @@ -43,7 +43,7 @@ var StyleDictionary = { format: require('./lib/common/formats'), action: require('./lib/common/actions'), formatHelpers: require('./lib/common/formatHelpers'), - filter: {}, // we need to initialise the object, since we don't have built-in filters + filter: require('./lib/common/filters'), parsers: [], // ditto ^ fileHeader: {}, diff --git a/lib/common/filters.js b/lib/common/filters.js new file mode 100644 index 000000000..af0e23d5e --- /dev/null +++ b/lib/common/filters.js @@ -0,0 +1,30 @@ +/* + * 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. + */ + +/** + * @namespace Filters + */ + +module.exports = { + /** + * Remove a token from the ditribution output if it contains a key `private` set to true + * + * @memberof Filters + * + * @param {Object} token + * @returns {Boolean} + */ + removePrivate: function(token) { + return (token && token.private) ? false : true + } +} From 4256681993091ab8dce94710e2c747dfeeca0674 Mon Sep 17 00:00:00 2001 From: Alessandro Rabitti Date: Wed, 2 Feb 2022 10:56:12 +0100 Subject: [PATCH 2/8] fix(lib): remove useless import --- scripts/version.js | 1 - 1 file changed, 1 deletion(-) diff --git a/scripts/version.js b/scripts/version.js index 994485779..7dc8cbad8 100644 --- a/scripts/version.js +++ b/scripts/version.js @@ -1,6 +1,5 @@ const fs = require('fs-extra'); const glob = require('glob'); -const path = require('path'); const execSync = require('child_process').execSync; const PACKAGE = require('../package.json'); const packageJSONs = glob.sync('./examples/*/*/package.json', {}); From 643a5ebe37159168a2e572ca82c34677d8e2ff7a Mon Sep 17 00:00:00 2001 From: Alessandro Rabitti Date: Wed, 2 Feb 2022 10:58:18 +0100 Subject: [PATCH 3/8] docs(example): add basic documentation for filters --- examples/advanced/filters/.gitignore | 2 + examples/advanced/filters/README.md | 5 + examples/advanced/filters/build.js | 32 + examples/advanced/filters/config.json | 21 + examples/advanced/filters/package-lock.json | 857 +++++++++++++++++++ examples/advanced/filters/package.json | 20 + examples/advanced/filters/tokens/colors.json | 30 + 7 files changed, 967 insertions(+) create mode 100644 examples/advanced/filters/.gitignore create mode 100644 examples/advanced/filters/README.md create mode 100644 examples/advanced/filters/build.js create mode 100644 examples/advanced/filters/config.json create mode 100644 examples/advanced/filters/package-lock.json create mode 100644 examples/advanced/filters/package.json create mode 100644 examples/advanced/filters/tokens/colors.json diff --git a/examples/advanced/filters/.gitignore b/examples/advanced/filters/.gitignore new file mode 100644 index 000000000..3e2e84b08 --- /dev/null +++ b/examples/advanced/filters/.gitignore @@ -0,0 +1,2 @@ +build/ +node_modules/ diff --git a/examples/advanced/filters/README.md b/examples/advanced/filters/README.md new file mode 100644 index 000000000..ef07f3eb4 --- /dev/null +++ b/examples/advanced/filters/README.md @@ -0,0 +1,5 @@ +## Filters + +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. diff --git a/examples/advanced/filters/build.js b/examples/advanced/filters/build.js new file mode 100644 index 000000000..730a2caa1 --- /dev/null +++ b/examples/advanced/filters/build.js @@ -0,0 +1,32 @@ +const StyleDictionary = require('style-dictionary'); + +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!'); diff --git a/examples/advanced/filters/config.json b/examples/advanced/filters/config.json new file mode 100644 index 000000000..04f4bacad --- /dev/null +++ b/examples/advanced/filters/config.json @@ -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" + }] + } + } +} diff --git a/examples/advanced/filters/package-lock.json b/examples/advanced/filters/package-lock.json new file mode 100644 index 000000000..e4372a4fd --- /dev/null +++ b/examples/advanced/filters/package-lock.json @@ -0,0 +1,857 @@ +{ + "name": "style-dictionary-custom-transforms", + "version": "1.0.0", + "lockfileVersion": 2, + "requires": true, + "packages": { + "": { + "name": "style-dictionary-custom-transforms", + "version": "1.0.0", + "license": "Apache-2.0", + "devDependencies": { + "style-dictionary": "3.1.1" + } + }, + "node_modules/ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "dependencies": { + "color-convert": "^2.0.1" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/balanced-match": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", + "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", + "dev": true + }, + "node_modules/brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "dependencies": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "node_modules/camel-case": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/camel-case/-/camel-case-4.1.2.tgz", + "integrity": "sha512-gxGWBrTT1JuMx6R+o5PTXMmUnhnVzLQ9SNutD4YqKtI6ap897t3tKECYla6gCWEkplXnlNybEkZg9GEGxKFCgw==", + "dev": true, + "dependencies": { + "pascal-case": "^3.1.2", + "tslib": "^2.0.3" + } + }, + "node_modules/capital-case": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/capital-case/-/capital-case-1.0.4.tgz", + "integrity": "sha512-ds37W8CytHgwnhGGTi88pcPyR15qoNkOpYwmMMfnWqqWgESapLqvDx6huFjQ5vqWSn2Z06173XNA7LtMOeUh1A==", + "dev": true, + "dependencies": { + "no-case": "^3.0.4", + "tslib": "^2.0.3", + "upper-case-first": "^2.0.2" + } + }, + "node_modules/chalk": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", + "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", + "dev": true, + "dependencies": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/chalk?sponsor=1" + } + }, + "node_modules/change-case": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/change-case/-/change-case-4.1.2.tgz", + "integrity": "sha512-bSxY2ws9OtviILG1EiY5K7NNxkqg/JnRnFxLtKQ96JaviiIxi7djMrSd0ECT9AC+lttClmYwKw53BWpOMblo7A==", + "dev": true, + "dependencies": { + "camel-case": "^4.1.2", + "capital-case": "^1.0.4", + "constant-case": "^3.0.4", + "dot-case": "^3.0.4", + "header-case": "^2.0.4", + "no-case": "^3.0.4", + "param-case": "^3.0.4", + "pascal-case": "^3.1.2", + "path-case": "^3.0.4", + "sentence-case": "^3.0.4", + "snake-case": "^3.0.4", + "tslib": "^2.0.3" + } + }, + "node_modules/color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "dependencies": { + "color-name": "~1.1.4" + }, + "engines": { + "node": ">=7.0.0" + } + }, + "node_modules/color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + }, + "node_modules/commander": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/commander/-/commander-5.1.0.tgz", + "integrity": "sha512-P0CysNDQ7rtVw4QIQtm+MRxV66vKFSvlsQvGYXZWR3qFU0jlMKHZZZgw8e+8DSah4UDKMqnknRDQz+xuQXQ/Zg==", + "dev": true, + "engines": { + "node": ">= 6" + } + }, + "node_modules/concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", + "dev": true + }, + "node_modules/constant-case": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/constant-case/-/constant-case-3.0.4.tgz", + "integrity": "sha512-I2hSBi7Vvs7BEuJDr5dDHfzb/Ruj3FyvFyh7KLilAjNQw3Be+xgqUBA2W6scVEcL0hL1dwPRtIqEPVUCKkSsyQ==", + "dev": true, + "dependencies": { + "no-case": "^3.0.4", + "tslib": "^2.0.3", + "upper-case": "^2.0.2" + } + }, + "node_modules/dot-case": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/dot-case/-/dot-case-3.0.4.tgz", + "integrity": "sha512-Kv5nKlh6yRrdrGvxeJ2e5y2eRUpkUosIW4A2AS38zwSz27zu7ufDwQPi5Jhs3XAlGNetl3bmnGhQsMtkKJnj3w==", + "dev": true, + "dependencies": { + "no-case": "^3.0.4", + "tslib": "^2.0.3" + } + }, + "node_modules/fs-extra": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-8.1.0.tgz", + "integrity": "sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==", + "dev": true, + "dependencies": { + "graceful-fs": "^4.2.0", + "jsonfile": "^4.0.0", + "universalify": "^0.1.0" + }, + "engines": { + "node": ">=6 <7 || >=8" + } + }, + "node_modules/fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", + "dev": true + }, + "node_modules/glob": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", + "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", + "dev": true, + "dependencies": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + }, + "engines": { + "node": "*" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/graceful-fs": { + "version": "4.2.9", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.9.tgz", + "integrity": "sha512-NtNxqUcXgpW2iMrfqSfR73Glt39K+BLwWsPs94yR63v45T0Wbej7eRmL5cWfwEgqXnmjQp3zaJTshdRW/qC2ZQ==", + "dev": true + }, + "node_modules/has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/header-case": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/header-case/-/header-case-2.0.4.tgz", + "integrity": "sha512-H/vuk5TEEVZwrR0lp2zed9OCo1uAILMlx0JEMgC26rzyJJ3N1v6XkwHHXJQdR2doSjcGPM6OKPYoJgf0plJ11Q==", + "dev": true, + "dependencies": { + "capital-case": "^1.0.4", + "tslib": "^2.0.3" + } + }, + "node_modules/inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", + "dev": true, + "dependencies": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "node_modules/inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", + "dev": true + }, + "node_modules/json5": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.0.tgz", + "integrity": "sha512-f+8cldu7X/y7RAJurMEJmdoKXGB/X550w2Nr3tTbezL6RwEE/iMcm+tZnXeoZtKuOq6ft8+CqzEkrIgx1fPoQA==", + "dev": true, + "dependencies": { + "minimist": "^1.2.5" + }, + "bin": { + "json5": "lib/cli.js" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/jsonc-parser": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/jsonc-parser/-/jsonc-parser-3.0.0.tgz", + "integrity": "sha512-fQzRfAbIBnR0IQvftw9FJveWiHp72Fg20giDrHz6TdfB12UH/uue0D3hm57UB5KgAVuniLMCaS8P1IMj9NR7cA==", + "dev": true + }, + "node_modules/jsonfile": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", + "integrity": "sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=", + "dev": true, + "optionalDependencies": { + "graceful-fs": "^4.1.6" + } + }, + "node_modules/lodash": { + "version": "4.17.21", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", + "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", + "dev": true + }, + "node_modules/lower-case": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/lower-case/-/lower-case-2.0.2.tgz", + "integrity": "sha512-7fm3l3NAF9WfN6W3JOmf5drwpVqX78JtoGJ3A6W0a6ZnldM41w2fV5D490psKFTpMds8TJse/eHLFFsNHHjHgg==", + "dev": true, + "dependencies": { + "tslib": "^2.0.3" + } + }, + "node_modules/minimatch": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", + "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", + "dev": true, + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, + "node_modules/minimist": { + "version": "1.2.5", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", + "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", + "dev": true + }, + "node_modules/no-case": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/no-case/-/no-case-3.0.4.tgz", + "integrity": "sha512-fgAN3jGAh+RoxUGZHTSOLJIqUc2wmoBwGR4tbpNAKmmovFoWq0OdRkb0VkldReO2a2iBT/OEulG9XSUc10r3zg==", + "dev": true, + "dependencies": { + "lower-case": "^2.0.2", + "tslib": "^2.0.3" + } + }, + "node_modules/once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", + "dev": true, + "dependencies": { + "wrappy": "1" + } + }, + "node_modules/param-case": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/param-case/-/param-case-3.0.4.tgz", + "integrity": "sha512-RXlj7zCYokReqWpOPH9oYivUzLYZ5vAPIfEmCTNViosC78F8F0H9y7T7gG2M39ymgutxF5gcFEsyZQSph9Bp3A==", + "dev": true, + "dependencies": { + "dot-case": "^3.0.4", + "tslib": "^2.0.3" + } + }, + "node_modules/pascal-case": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/pascal-case/-/pascal-case-3.1.2.tgz", + "integrity": "sha512-uWlGT3YSnK9x3BQJaOdcZwrnV6hPpd8jFH1/ucpiLRPh/2zCVJKS19E4GvYHvaCcACn3foXZ0cLB9Wrx1KGe5g==", + "dev": true, + "dependencies": { + "no-case": "^3.0.4", + "tslib": "^2.0.3" + } + }, + "node_modules/path-case": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/path-case/-/path-case-3.0.4.tgz", + "integrity": "sha512-qO4qCFjXqVTrcbPt/hQfhTQ+VhFsqNKOPtytgNKkKxSoEp3XPUQ8ObFuePylOIok5gjn69ry8XiULxCwot3Wfg==", + "dev": true, + "dependencies": { + "dot-case": "^3.0.4", + "tslib": "^2.0.3" + } + }, + "node_modules/path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/sentence-case": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/sentence-case/-/sentence-case-3.0.4.tgz", + "integrity": "sha512-8LS0JInaQMCRoQ7YUytAo/xUu5W2XnQxV2HI/6uM6U7CITS1RqPElr30V6uIqyMKM9lJGRVFy5/4CuzcixNYSg==", + "dev": true, + "dependencies": { + "no-case": "^3.0.4", + "tslib": "^2.0.3", + "upper-case-first": "^2.0.2" + } + }, + "node_modules/snake-case": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/snake-case/-/snake-case-3.0.4.tgz", + "integrity": "sha512-LAOh4z89bGQvl9pFfNF8V146i7o7/CqFPbqzYgP+yYzDIDeS9HaNFtXABamRW+AQzEVODcvE79ljJ+8a9YSdMg==", + "dev": true, + "dependencies": { + "dot-case": "^3.0.4", + "tslib": "^2.0.3" + } + }, + "node_modules/style-dictionary": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/style-dictionary/-/style-dictionary-3.1.1.tgz", + "integrity": "sha512-Dpugx2wH3ElMvq1GOaSsfUChr8dwujx2/eBUUd0vaSFkP16LRp5XOJMTHF0f8QuPGkpBfVPXDWCkb3oJ3oJjxg==", + "dev": true, + "dependencies": { + "chalk": "^4.0.0", + "change-case": "^4.1.2", + "commander": "^5.1.0", + "fs-extra": "^8.1.0", + "glob": "^7.1.6", + "json5": "^2.1.3", + "jsonc-parser": "^3.0.0", + "lodash": "^4.17.15", + "tinycolor2": "^1.4.1" + }, + "bin": { + "style-dictionary": "bin/style-dictionary" + }, + "engines": { + "node": ">=12.0.0" + } + }, + "node_modules/supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "dependencies": { + "has-flag": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/tinycolor2": { + "version": "1.4.2", + "resolved": "https://registry.npmjs.org/tinycolor2/-/tinycolor2-1.4.2.tgz", + "integrity": "sha512-vJhccZPs965sV/L2sU4oRQVAos0pQXwsvTLkWYdqJ+a8Q5kPFzJTuOFwy7UniPli44NKQGAglksjvOcpo95aZA==", + "dev": true, + "engines": { + "node": "*" + } + }, + "node_modules/tslib": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.3.1.tgz", + "integrity": "sha512-77EbyPPpMz+FRFRuAFlWMtmgUWGe9UOG2Z25NqCwiIjRhOf5iKGuzSe5P2w1laq+FkRy4p+PCuVkJSGkzTEKVw==", + "dev": true + }, + "node_modules/universalify": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", + "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==", + "dev": true, + "engines": { + "node": ">= 4.0.0" + } + }, + "node_modules/upper-case": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/upper-case/-/upper-case-2.0.2.tgz", + "integrity": "sha512-KgdgDGJt2TpuwBUIjgG6lzw2GWFRCW9Qkfkiv0DxqHHLYJHmtmdUIKcZd8rHgFSjopVTlw6ggzCm1b8MFQwikg==", + "dev": true, + "dependencies": { + "tslib": "^2.0.3" + } + }, + "node_modules/upper-case-first": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/upper-case-first/-/upper-case-first-2.0.2.tgz", + "integrity": "sha512-514ppYHBaKwfJRK/pNC6c/OxfGa0obSnAl106u97Ed0I625Nin96KAjttZF6ZL3e1XLtphxnqrOi9iWgm+u+bg==", + "dev": true, + "dependencies": { + "tslib": "^2.0.3" + } + }, + "node_modules/wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", + "dev": true + } + }, + "dependencies": { + "ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "requires": { + "color-convert": "^2.0.1" + } + }, + "balanced-match": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", + "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", + "dev": true + }, + "brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "requires": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "camel-case": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/camel-case/-/camel-case-4.1.2.tgz", + "integrity": "sha512-gxGWBrTT1JuMx6R+o5PTXMmUnhnVzLQ9SNutD4YqKtI6ap897t3tKECYla6gCWEkplXnlNybEkZg9GEGxKFCgw==", + "dev": true, + "requires": { + "pascal-case": "^3.1.2", + "tslib": "^2.0.3" + } + }, + "capital-case": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/capital-case/-/capital-case-1.0.4.tgz", + "integrity": "sha512-ds37W8CytHgwnhGGTi88pcPyR15qoNkOpYwmMMfnWqqWgESapLqvDx6huFjQ5vqWSn2Z06173XNA7LtMOeUh1A==", + "dev": true, + "requires": { + "no-case": "^3.0.4", + "tslib": "^2.0.3", + "upper-case-first": "^2.0.2" + } + }, + "chalk": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", + "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", + "dev": true, + "requires": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + } + }, + "change-case": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/change-case/-/change-case-4.1.2.tgz", + "integrity": "sha512-bSxY2ws9OtviILG1EiY5K7NNxkqg/JnRnFxLtKQ96JaviiIxi7djMrSd0ECT9AC+lttClmYwKw53BWpOMblo7A==", + "dev": true, + "requires": { + "camel-case": "^4.1.2", + "capital-case": "^1.0.4", + "constant-case": "^3.0.4", + "dot-case": "^3.0.4", + "header-case": "^2.0.4", + "no-case": "^3.0.4", + "param-case": "^3.0.4", + "pascal-case": "^3.1.2", + "path-case": "^3.0.4", + "sentence-case": "^3.0.4", + "snake-case": "^3.0.4", + "tslib": "^2.0.3" + } + }, + "color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "requires": { + "color-name": "~1.1.4" + } + }, + "color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + }, + "commander": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/commander/-/commander-5.1.0.tgz", + "integrity": "sha512-P0CysNDQ7rtVw4QIQtm+MRxV66vKFSvlsQvGYXZWR3qFU0jlMKHZZZgw8e+8DSah4UDKMqnknRDQz+xuQXQ/Zg==", + "dev": true + }, + "concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", + "dev": true + }, + "constant-case": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/constant-case/-/constant-case-3.0.4.tgz", + "integrity": "sha512-I2hSBi7Vvs7BEuJDr5dDHfzb/Ruj3FyvFyh7KLilAjNQw3Be+xgqUBA2W6scVEcL0hL1dwPRtIqEPVUCKkSsyQ==", + "dev": true, + "requires": { + "no-case": "^3.0.4", + "tslib": "^2.0.3", + "upper-case": "^2.0.2" + } + }, + "dot-case": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/dot-case/-/dot-case-3.0.4.tgz", + "integrity": "sha512-Kv5nKlh6yRrdrGvxeJ2e5y2eRUpkUosIW4A2AS38zwSz27zu7ufDwQPi5Jhs3XAlGNetl3bmnGhQsMtkKJnj3w==", + "dev": true, + "requires": { + "no-case": "^3.0.4", + "tslib": "^2.0.3" + } + }, + "fs-extra": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-8.1.0.tgz", + "integrity": "sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==", + "dev": true, + "requires": { + "graceful-fs": "^4.2.0", + "jsonfile": "^4.0.0", + "universalify": "^0.1.0" + } + }, + "fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", + "dev": true + }, + "glob": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", + "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", + "dev": true, + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, + "graceful-fs": { + "version": "4.2.9", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.9.tgz", + "integrity": "sha512-NtNxqUcXgpW2iMrfqSfR73Glt39K+BLwWsPs94yR63v45T0Wbej7eRmL5cWfwEgqXnmjQp3zaJTshdRW/qC2ZQ==", + "dev": true + }, + "has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "dev": true + }, + "header-case": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/header-case/-/header-case-2.0.4.tgz", + "integrity": "sha512-H/vuk5TEEVZwrR0lp2zed9OCo1uAILMlx0JEMgC26rzyJJ3N1v6XkwHHXJQdR2doSjcGPM6OKPYoJgf0plJ11Q==", + "dev": true, + "requires": { + "capital-case": "^1.0.4", + "tslib": "^2.0.3" + } + }, + "inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", + "dev": true, + "requires": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", + "dev": true + }, + "json5": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.0.tgz", + "integrity": "sha512-f+8cldu7X/y7RAJurMEJmdoKXGB/X550w2Nr3tTbezL6RwEE/iMcm+tZnXeoZtKuOq6ft8+CqzEkrIgx1fPoQA==", + "dev": true, + "requires": { + "minimist": "^1.2.5" + } + }, + "jsonc-parser": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/jsonc-parser/-/jsonc-parser-3.0.0.tgz", + "integrity": "sha512-fQzRfAbIBnR0IQvftw9FJveWiHp72Fg20giDrHz6TdfB12UH/uue0D3hm57UB5KgAVuniLMCaS8P1IMj9NR7cA==", + "dev": true + }, + "jsonfile": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", + "integrity": "sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=", + "dev": true, + "requires": { + "graceful-fs": "^4.1.6" + } + }, + "lodash": { + "version": "4.17.21", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", + "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", + "dev": true + }, + "lower-case": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/lower-case/-/lower-case-2.0.2.tgz", + "integrity": "sha512-7fm3l3NAF9WfN6W3JOmf5drwpVqX78JtoGJ3A6W0a6ZnldM41w2fV5D490psKFTpMds8TJse/eHLFFsNHHjHgg==", + "dev": true, + "requires": { + "tslib": "^2.0.3" + } + }, + "minimatch": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", + "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", + "dev": true, + "requires": { + "brace-expansion": "^1.1.7" + } + }, + "minimist": { + "version": "1.2.5", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", + "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", + "dev": true + }, + "no-case": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/no-case/-/no-case-3.0.4.tgz", + "integrity": "sha512-fgAN3jGAh+RoxUGZHTSOLJIqUc2wmoBwGR4tbpNAKmmovFoWq0OdRkb0VkldReO2a2iBT/OEulG9XSUc10r3zg==", + "dev": true, + "requires": { + "lower-case": "^2.0.2", + "tslib": "^2.0.3" + } + }, + "once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", + "dev": true, + "requires": { + "wrappy": "1" + } + }, + "param-case": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/param-case/-/param-case-3.0.4.tgz", + "integrity": "sha512-RXlj7zCYokReqWpOPH9oYivUzLYZ5vAPIfEmCTNViosC78F8F0H9y7T7gG2M39ymgutxF5gcFEsyZQSph9Bp3A==", + "dev": true, + "requires": { + "dot-case": "^3.0.4", + "tslib": "^2.0.3" + } + }, + "pascal-case": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/pascal-case/-/pascal-case-3.1.2.tgz", + "integrity": "sha512-uWlGT3YSnK9x3BQJaOdcZwrnV6hPpd8jFH1/ucpiLRPh/2zCVJKS19E4GvYHvaCcACn3foXZ0cLB9Wrx1KGe5g==", + "dev": true, + "requires": { + "no-case": "^3.0.4", + "tslib": "^2.0.3" + } + }, + "path-case": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/path-case/-/path-case-3.0.4.tgz", + "integrity": "sha512-qO4qCFjXqVTrcbPt/hQfhTQ+VhFsqNKOPtytgNKkKxSoEp3XPUQ8ObFuePylOIok5gjn69ry8XiULxCwot3Wfg==", + "dev": true, + "requires": { + "dot-case": "^3.0.4", + "tslib": "^2.0.3" + } + }, + "path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", + "dev": true + }, + "sentence-case": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/sentence-case/-/sentence-case-3.0.4.tgz", + "integrity": "sha512-8LS0JInaQMCRoQ7YUytAo/xUu5W2XnQxV2HI/6uM6U7CITS1RqPElr30V6uIqyMKM9lJGRVFy5/4CuzcixNYSg==", + "dev": true, + "requires": { + "no-case": "^3.0.4", + "tslib": "^2.0.3", + "upper-case-first": "^2.0.2" + } + }, + "snake-case": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/snake-case/-/snake-case-3.0.4.tgz", + "integrity": "sha512-LAOh4z89bGQvl9pFfNF8V146i7o7/CqFPbqzYgP+yYzDIDeS9HaNFtXABamRW+AQzEVODcvE79ljJ+8a9YSdMg==", + "dev": true, + "requires": { + "dot-case": "^3.0.4", + "tslib": "^2.0.3" + } + }, + "style-dictionary": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/style-dictionary/-/style-dictionary-3.1.1.tgz", + "integrity": "sha512-Dpugx2wH3ElMvq1GOaSsfUChr8dwujx2/eBUUd0vaSFkP16LRp5XOJMTHF0f8QuPGkpBfVPXDWCkb3oJ3oJjxg==", + "dev": true, + "requires": { + "chalk": "^4.0.0", + "change-case": "^4.1.2", + "commander": "^5.1.0", + "fs-extra": "^8.1.0", + "glob": "^7.1.6", + "json5": "^2.1.3", + "jsonc-parser": "^3.0.0", + "lodash": "^4.17.15", + "tinycolor2": "^1.4.1" + } + }, + "supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "requires": { + "has-flag": "^4.0.0" + } + }, + "tinycolor2": { + "version": "1.4.2", + "resolved": "https://registry.npmjs.org/tinycolor2/-/tinycolor2-1.4.2.tgz", + "integrity": "sha512-vJhccZPs965sV/L2sU4oRQVAos0pQXwsvTLkWYdqJ+a8Q5kPFzJTuOFwy7UniPli44NKQGAglksjvOcpo95aZA==", + "dev": true + }, + "tslib": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.3.1.tgz", + "integrity": "sha512-77EbyPPpMz+FRFRuAFlWMtmgUWGe9UOG2Z25NqCwiIjRhOf5iKGuzSe5P2w1laq+FkRy4p+PCuVkJSGkzTEKVw==", + "dev": true + }, + "universalify": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", + "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==", + "dev": true + }, + "upper-case": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/upper-case/-/upper-case-2.0.2.tgz", + "integrity": "sha512-KgdgDGJt2TpuwBUIjgG6lzw2GWFRCW9Qkfkiv0DxqHHLYJHmtmdUIKcZd8rHgFSjopVTlw6ggzCm1b8MFQwikg==", + "dev": true, + "requires": { + "tslib": "^2.0.3" + } + }, + "upper-case-first": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/upper-case-first/-/upper-case-first-2.0.2.tgz", + "integrity": "sha512-514ppYHBaKwfJRK/pNC6c/OxfGa0obSnAl106u97Ed0I625Nin96KAjttZF6ZL3e1XLtphxnqrOi9iWgm+u+bg==", + "dev": true, + "requires": { + "tslib": "^2.0.3" + } + }, + "wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", + "dev": true + } + } +} diff --git a/examples/advanced/filters/package.json b/examples/advanced/filters/package.json new file mode 100644 index 000000000..c3d875e8e --- /dev/null +++ b/examples/advanced/filters/package.json @@ -0,0 +1,20 @@ +{ + "name": "style-dictionary-filters", + "version": "1.0.0", + "description": "", + "main": "build/index.js", + "files": [ + "build", + "properties" + ], + "scripts": { + "build": "node ./build.js", + "clean": "rm -rf build", + "test": "echo \"Error: no test specified\" && exit 1" + }, + "author": "", + "license": "Apache-2.0", + "devDependencies": { + "style-dictionary": "3.1.1" + } +} diff --git a/examples/advanced/filters/tokens/colors.json b/examples/advanced/filters/tokens/colors.json new file mode 100644 index 000000000..e2cd3792c --- /dev/null +++ b/examples/advanced/filters/tokens/colors.json @@ -0,0 +1,30 @@ +{ + "color": { + "base": { + "gray": { + "light" : { + "value": "#CCCCCC", + "group": "color", + "private": true + }, + "medium": { + "value": "#999999", + "group": "color" + }, + "dark" : { + "value": "#111111", + "group": "color" + } + }, + "red": { + "value": "#FF0000", + "group": "color", + "private": true + }, + "green": { + "value": "#00FF00", + "group": "color" + } + } + } +} From 3e1244de176dee98bdca54d135d21dc93a66d330 Mon Sep 17 00:00:00 2001 From: Alessandro Rabitti Date: Wed, 2 Feb 2022 13:06:19 +0100 Subject: [PATCH 4/8] docs(example): fix require of current styledictionary lib --- examples/advanced/filters/build.js | 2 +- examples/advanced/filters/package-lock.json | 12 ++++-------- examples/advanced/filters/package.json | 5 +---- 3 files changed, 6 insertions(+), 13 deletions(-) diff --git a/examples/advanced/filters/build.js b/examples/advanced/filters/build.js index 730a2caa1..1d4654c09 100644 --- a/examples/advanced/filters/build.js +++ b/examples/advanced/filters/build.js @@ -1,4 +1,4 @@ -const StyleDictionary = require('style-dictionary'); +const StyleDictionary = require('../../../index'); console.log('Build started...'); console.log('\n=============================================='); diff --git a/examples/advanced/filters/package-lock.json b/examples/advanced/filters/package-lock.json index e4372a4fd..6b85e911c 100644 --- a/examples/advanced/filters/package-lock.json +++ b/examples/advanced/filters/package-lock.json @@ -1,16 +1,13 @@ { - "name": "style-dictionary-custom-transforms", + "name": "style-dictionary-filters", "version": "1.0.0", "lockfileVersion": 2, "requires": true, "packages": { "": { - "name": "style-dictionary-custom-transforms", + "name": "style-dictionary-filters", "version": "1.0.0", - "license": "Apache-2.0", - "devDependencies": { - "style-dictionary": "3.1.1" - } + "license": "Apache-2.0" }, "node_modules/ansi-styles": { "version": "4.3.0", @@ -786,8 +783,7 @@ } }, "style-dictionary": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/style-dictionary/-/style-dictionary-3.1.1.tgz", + "version": "https://registry.npmjs.org/style-dictionary/-/style-dictionary-3.1.1.tgz", "integrity": "sha512-Dpugx2wH3ElMvq1GOaSsfUChr8dwujx2/eBUUd0vaSFkP16LRp5XOJMTHF0f8QuPGkpBfVPXDWCkb3oJ3oJjxg==", "dev": true, "requires": { diff --git a/examples/advanced/filters/package.json b/examples/advanced/filters/package.json index c3d875e8e..a0461ec09 100644 --- a/examples/advanced/filters/package.json +++ b/examples/advanced/filters/package.json @@ -13,8 +13,5 @@ "test": "echo \"Error: no test specified\" && exit 1" }, "author": "", - "license": "Apache-2.0", - "devDependencies": { - "style-dictionary": "3.1.1" - } + "license": "Apache-2.0" } From 1e35f8420cf600a42b579409ab8dab6b996217ab Mon Sep 17 00:00:00 2001 From: Alessandro Rabitti Date: Wed, 2 Feb 2022 17:23:18 +0100 Subject: [PATCH 5/8] fix(example): adjust indentation --- examples/advanced/filters/build.js | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/examples/advanced/filters/build.js b/examples/advanced/filters/build.js index 1d4654c09..fc51f6974 100644 --- a/examples/advanced/filters/build.js +++ b/examples/advanced/filters/build.js @@ -10,11 +10,11 @@ StyleDictionary.registerTransform({ name: 'hexRGB/hexARGB', type: 'value', matcher: function(token) { - return token.group === 'color'; + 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'); + // for sake of simplicity, in this example we assume colors are always in the format #xxxxxx + return token.value.replace(/^#/,'#FF'); } }); From e0f8f353425638d1f8c8b036d62ab7664936df55 Mon Sep 17 00:00:00 2001 From: Alessandro Rabitti Date: Wed, 2 Feb 2022 17:23:59 +0100 Subject: [PATCH 6/8] docs(example): add information to filters README.md --- examples/advanced/filters/README.md | 94 +++++++++++++++++++++++++++++ 1 file changed, 94 insertions(+) diff --git a/examples/advanced/filters/README.md b/examples/advanced/filters/README.md index ef07f3eb4..8978bb102 100644 --- a/examples/advanced/filters/README.md +++ b/examples/advanced/filters/README.md @@ -3,3 +3,97 @@ 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). From de64b9152782e180e4a93107aa2971a1b6153852 Mon Sep 17 00:00:00 2001 From: Alessandro Rabitti Date: Fri, 4 Feb 2022 21:48:33 +0100 Subject: [PATCH 7/8] docs(example): improve basic documentation for custom filters --- .../{filters => custom-filters}/.gitignore | 0 .../{filters => custom-filters}/README.md | 0 .../{filters => custom-filters}/build.js | 13 +++----- .../{filters => custom-filters}/config.json | 4 +-- .../package-lock.json | 0 .../{filters => custom-filters}/package.json | 0 .../custom-filters/tokens/spacing.json | 20 +++++++++++++ examples/advanced/filters/tokens/colors.json | 30 ------------------- 8 files changed, 26 insertions(+), 41 deletions(-) rename examples/advanced/{filters => custom-filters}/.gitignore (100%) rename examples/advanced/{filters => custom-filters}/README.md (100%) rename examples/advanced/{filters => custom-filters}/build.js (64%) rename examples/advanced/{filters => custom-filters}/config.json (82%) rename examples/advanced/{filters => custom-filters}/package-lock.json (100%) rename examples/advanced/{filters => custom-filters}/package.json (100%) create mode 100644 examples/advanced/custom-filters/tokens/spacing.json delete mode 100644 examples/advanced/filters/tokens/colors.json diff --git a/examples/advanced/filters/.gitignore b/examples/advanced/custom-filters/.gitignore similarity index 100% rename from examples/advanced/filters/.gitignore rename to examples/advanced/custom-filters/.gitignore diff --git a/examples/advanced/filters/README.md b/examples/advanced/custom-filters/README.md similarity index 100% rename from examples/advanced/filters/README.md rename to examples/advanced/custom-filters/README.md diff --git a/examples/advanced/filters/build.js b/examples/advanced/custom-filters/build.js similarity index 64% rename from examples/advanced/filters/build.js rename to examples/advanced/custom-filters/build.js index fc51f6974..a060de86f 100644 --- a/examples/advanced/filters/build.js +++ b/examples/advanced/custom-filters/build.js @@ -4,17 +4,12 @@ console.log('Build started...'); console.log('\n=============================================='); -// REGISTER THE CUSTOM TRANFORMS +// REGISTER THE CUSTOM FILTERS -StyleDictionary.registerTransform({ - name: 'hexRGB/hexARGB', - type: 'value', +StyleDictionary.registerFilter({ + name: 'removeBigSpacing', 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'); + return token.group === 'spacing' && token.value < 0.5 } }); diff --git a/examples/advanced/filters/config.json b/examples/advanced/custom-filters/config.json similarity index 82% rename from examples/advanced/filters/config.json rename to examples/advanced/custom-filters/config.json index 04f4bacad..a6d7f396a 100644 --- a/examples/advanced/filters/config.json +++ b/examples/advanced/custom-filters/config.json @@ -5,7 +5,7 @@ "buildPath": "build/web/", "files": [{ "destination": "tokens.js", - "filter": "removePrivate", + "filter": "removeBigSpacing", "format": "javascript/es6" }] }, @@ -13,7 +13,7 @@ "buildPath": "build/web/", "files": [{ "destination": "tokens.scss", - "filter": "removePrivate", + "filter": "removeBigSpacing", "format": "scss/variables" }] } diff --git a/examples/advanced/filters/package-lock.json b/examples/advanced/custom-filters/package-lock.json similarity index 100% rename from examples/advanced/filters/package-lock.json rename to examples/advanced/custom-filters/package-lock.json diff --git a/examples/advanced/filters/package.json b/examples/advanced/custom-filters/package.json similarity index 100% rename from examples/advanced/filters/package.json rename to examples/advanced/custom-filters/package.json diff --git a/examples/advanced/custom-filters/tokens/spacing.json b/examples/advanced/custom-filters/tokens/spacing.json new file mode 100644 index 000000000..1876a7ad7 --- /dev/null +++ b/examples/advanced/custom-filters/tokens/spacing.json @@ -0,0 +1,20 @@ +{ + "margin": { + "small" : { + "value": "0.15", + "group": "spacing" + }, + "medium": { + "value": "0.25", + "group": "spacing" + }, + "large" : { + "value": "0.6", + "group": "spacing" + }, + "extralarge" : { + "value": "1", + "group": "spacing" + } + } +} diff --git a/examples/advanced/filters/tokens/colors.json b/examples/advanced/filters/tokens/colors.json deleted file mode 100644 index e2cd3792c..000000000 --- a/examples/advanced/filters/tokens/colors.json +++ /dev/null @@ -1,30 +0,0 @@ -{ - "color": { - "base": { - "gray": { - "light" : { - "value": "#CCCCCC", - "group": "color", - "private": true - }, - "medium": { - "value": "#999999", - "group": "color" - }, - "dark" : { - "value": "#111111", - "group": "color" - } - }, - "red": { - "value": "#FF0000", - "group": "color", - "private": true - }, - "green": { - "value": "#00FF00", - "group": "color" - } - } - } -} From 876a377bcf7455946d58c90b9f59d20d811f114c Mon Sep 17 00:00:00 2001 From: Alessandro Rabitti Date: Mon, 7 Feb 2022 11:16:56 +0100 Subject: [PATCH 8/8] fix(docs): add missing comment in index.js --- index.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/index.js b/index.js index 536443c2d..14ec78ad5 100644 --- a/index.js +++ b/index.js @@ -44,7 +44,7 @@ var StyleDictionary = { action: require('./lib/common/actions'), formatHelpers: require('./lib/common/formatHelpers'), filter: require('./lib/common/filters'), - parsers: [], // ditto ^ + parsers: [], // we need to initialise the array, since we don't have built-in parsers fileHeader: {}, registerTransform: require('./lib/register/transform'),