Skip to content

Commit

Permalink
feat: expose typeW3CDelegate util function (#1087)
Browse files Browse the repository at this point in the history
* feat: expose typeW3CDelegate util function

* fix: small bug with w3c type delegate util (#1088)
  • Loading branch information
jorenbroekema authored Jan 25, 2024
1 parent 7a1e446 commit 0c1a36f
Show file tree
Hide file tree
Showing 8 changed files with 178 additions and 4 deletions.
5 changes: 5 additions & 0 deletions .changeset/grumpy-peaches-flow.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
'style-dictionary': patch
---

Fix small issue in type w3c delegate utility type tracking.
5 changes: 5 additions & 0 deletions .changeset/ninety-geckos-build.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
'style-dictionary': patch
---

Expose typeW3CDelegate utility. Don't take "value" into account anymore to determine that it's a design token, use $value.
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ snapshots["should match snapshot"] =
:root {
--colors-black-500: rgb(0, 0, 0);
--colors-black-dimension: 5px; /* Some description */
--colors-foo: rgb(0, 0, 0);
}
`;
/* end snapshot should match snapshot */
Expand Down
3 changes: 3 additions & 0 deletions __integration__/w3c-forward-compat.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,9 @@ describe('integration', () => {
$description: 'Some description',
},
},
foo: {
$value: '{colors.black.500}',
},
},
},
transform: {
Expand Down
96 changes: 96 additions & 0 deletions __tests__/utils/preprocess.test.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,96 @@
/*
* 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.
*/
import { expect } from 'chai';
import { typeW3CDelegate } from '../../lib/utils/preprocess.js';

describe('utils', () => {
describe('typeW3CDelegate', () => {
it('should correctly let tokens inherit the $type property while respecting local overrides', () => {
const tokens = {
dimension: {
$type: 'dimension',
scale: {
$value: '2',
$type: 'math',
},
xs: {
$value: '4',
},
nested: {
deep: {
deeper: {
$value: '12',
},
},
deep2: {
$type: 'math',
deeper: {
$type: 'other',
evenDeeper: {
$value: '12',
$type: 'math',
},
evenDeeper2: {
$value: '12',
},
},
},
},
sm: {
$value: '8',
},
},
};

expect(typeW3CDelegate(tokens)).to.eql({
dimension: {
$type: 'dimension',
scale: {
$value: '2',
$type: 'math',
},
xs: {
$value: '4',
$type: 'dimension',
},
nested: {
deep: {
deeper: {
$value: '12',
$type: 'dimension',
},
},
deep2: {
$type: 'math',
deeper: {
$type: 'other',
evenDeeper: {
$value: '12',
$type: 'math',
},
evenDeeper2: {
$value: '12',
$type: 'other',
},
},
},
},
sm: {
$value: '8',
$type: 'dimension',
},
},
});
});
});
});
63 changes: 63 additions & 0 deletions docs/using_reference_utils.md
Original file line number Diff line number Diff line change
Expand Up @@ -264,3 +264,66 @@ export const ZIndexAboveFold = 1;
export const SemanticBgPrimary = ColorsBlack;
export const Border = `solid ${Spacing2} ${SemanticBgPrimary}`;
```

### typeW3CDelegate

This function processes your ["W3C Design Token Community Group Draft spec"-compliant](https://design-tokens.github.io/community-group/format/) dictionary of tokens, and ensures that `$type` inheritance is applied.

We built this utility because it's cheaper to apply the inheritance once, rather than on every access of a token's "$type" property, checking the ancestor tree to find it.

Input:

```js
{
dimensions: {
$type: 'dimension',
sm: {
$value: '5',
},
md: {
$value: '10',
},
nested: {
deep: {
lg: {
$value: '15',
},
},
},
nope: {
$value: '20',
$type: 'spacing',
},
},
}
```

Output:

```js
{
dimensions: {
$type: 'dimension',
sm: {
$value: '5',
$type: 'dimension',
},
md: {
$value: '10',
$type: 'dimension',
},
nested: {
deep: {
lg: {
$value: '15',
$type: 'dimension',
},
},
},
nope: {
$value: '20',
$type: 'spacing',
},
},
}
```
3 changes: 2 additions & 1 deletion lib/utils/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ import usesReferences from './references/usesReferences.js';
import { getReferences } from './references/getReferences.js';
import { resolveReferences } from './references/resolveReferences.js';
import flattenTokens from './flattenTokens.js';
import { typeW3CDelegate } from './preprocess.js';

// Public style-dictionary/utils API
export { usesReferences, getReferences, resolveReferences, flattenTokens };
export { usesReferences, getReferences, resolveReferences, flattenTokens, typeW3CDelegate };
6 changes: 3 additions & 3 deletions lib/utils/preprocess.js
Original file line number Diff line number Diff line change
Expand Up @@ -23,23 +23,23 @@ import isPlainObject from 'is-plain-obj';
* @param {DesignTokens} tokens
* @returns
*/
function typeW3CDelegate(tokens) {
export function typeW3CDelegate(tokens) {
const clone = structuredClone(tokens);

/**
* @param {DesignTokens} slice
* @param {string} [_type]
*/
const recurse = (slice, _type) => {
let type = _type; // keep track of type through the stack
Object.values(slice).forEach((prop) => {
let type = _type; // keep track of type through the stack
if (isPlainObject(prop)) {
if (typeof prop.$type === 'string') {
type = prop.$type;
}
// prop is a design token, but no $type prop currently,
// so we add it if we know what the type is from our ancestor tree
if ((prop.$value || prop.value) && !prop.$type && type) {
if (prop.$value && !prop.$type && type) {
prop.$type = type;
}
recurse(prop, type);
Expand Down

0 comments on commit 0c1a36f

Please sign in to comment.