Skip to content

Commit

Permalink
timingFunction and fontFamily props, optional border props (#1229)
Browse files Browse the repository at this point in the history
* fix: support optional props border tokens

* fix: handle timingFunction and fontFamily props in transforms
  • Loading branch information
jorenbroekema committed Jun 28, 2024
1 parent 02847e3 commit bc77590
Show file tree
Hide file tree
Showing 8 changed files with 196 additions and 72 deletions.
5 changes: 5 additions & 0 deletions .changeset/strong-tools-draw.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
'style-dictionary': minor
---

Handle transition timingFunction prop in cubicBezier/css transform. Handle typography fontFamily prop in fontFamily/css transform.
5 changes: 5 additions & 0 deletions .changeset/witty-glasses-hear.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
'style-dictionary': patch
---

Allow border type tokens to be empty, every property is optional.
4 changes: 0 additions & 4 deletions __tests__/cleanDir.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,10 +16,6 @@ import StyleDictionary from '../lib/StyleDictionary.js';
import cleanFile from '../lib/cleanFile.js';
import cleanDir from '../lib/cleanDir.js';

function format() {
return 'hi';
}

describe('cleanDir', () => {
beforeEach(() => {
clearOutput();
Expand Down
147 changes: 111 additions & 36 deletions __tests__/common/transforms.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -1049,39 +1049,132 @@ describe('common', () => {
});

describe('fontFamily/css', () => {
const fontFamilyTransform = (value) =>
transforms['fontFamily/css'].transform({ value }, {}, {});
const fontFamilyTransform = (token) => transforms['fontFamily/css'].transform(token, {}, {});

it('should handle simple fontFamily as is', () => {
expect(fontFamilyTransform('Arial')).to.equal('Arial');
expect(fontFamilyTransform({ value: 'Arial', type: 'fontFamily' })).to.equal('Arial');
});

it('should comma separated type fontFamily values', () => {
expect(fontFamilyTransform('Arial, sans-serif')).to.equal('Arial, sans-serif');
expect(fontFamilyTransform({ value: 'Arial, sans-serif', type: 'fontFamily' })).to.equal(
'Arial, sans-serif',
);
});

it('should handle array type fontFamily values', () => {
expect(fontFamilyTransform(['Arial', 'sans-serif'])).to.equal('Arial, sans-serif');
expect(
fontFamilyTransform({ value: ['Arial', 'sans-serif'], type: 'fontFamily' }),
).to.equal('Arial, sans-serif');
});

it('should wrap fontFamily values with spaces in quotes', () => {
expect(fontFamilyTransform('Gill Sans')).to.equal("'Gill Sans'");
expect(fontFamilyTransform('Gill Sans, Arial, Comic Sans, Open Sans, sans-serif')).to.equal(
"'Gill Sans', Arial, 'Comic Sans', 'Open Sans', sans-serif",
expect(fontFamilyTransform({ value: 'Gill Sans', type: 'fontFamily' })).to.equal(
"'Gill Sans'",
);
expect(
fontFamilyTransform(['Gill Sans', 'Arial', 'Comic Sans', 'Open Sans', 'sans-serif']),
fontFamilyTransform({
value: 'Gill Sans, Arial, Comic Sans, Open Sans, sans-serif',
type: 'fontFamily',
}),
).to.equal("'Gill Sans', Arial, 'Comic Sans', 'Open Sans', sans-serif");
expect(
fontFamilyTransform({
value: ['Gill Sans', 'Arial', 'Comic Sans', 'Open Sans', 'sans-serif'],
type: 'fontFamily',
}),
).to.equal("'Gill Sans', Arial, 'Comic Sans', 'Open Sans', sans-serif");
});

it('should handle fontFamily prop within typography tokens', () => {
expect(
fontFamilyTransform({
value: {
fontFamily: ['Gill Sans', 'sans-serif'],
fontWeight: 300,
fontSize: '20px',
lineHeight: '1.5',
},
type: 'typography',
}),
).to.eql({
fontFamily: "'Gill Sans', sans-serif",
fontWeight: 300,
fontSize: '20px',
lineHeight: '1.5',
});

expect(
fontFamilyTransform({
value: {
fontWeight: 300,
fontSize: '20px',
lineHeight: '1.5',
},
type: 'typography',
}),
).to.eql({
fontWeight: 300,
fontSize: '20px',
lineHeight: '1.5',
});
});
});

describe('cubicBezier/css', () => {
const cubicBezierTransform = (value) =>
transforms['cubicBezier/css'].transform({ value }, {}, {});
const cubicBezierTransform = (token) =>
transforms['cubicBezier/css'].transform(token, {}, {});

it('should stringify cubicBezier values to cubicBezier() CSS function', () => {
expect(cubicBezierTransform([0.5, 0, 1, 1])).to.equal('cubic-bezier(0.5, 0, 1, 1)');
expect('ease-in-out').to.equal('ease-in-out');
expect(cubicBezierTransform({ value: [0.5, 0, 1, 1], type: 'cubicBezier' })).to.equal(
'cubic-bezier(0.5, 0, 1, 1)',
);
expect(cubicBezierTransform({ value: 'ease-in-out', type: 'cubicBezier' })).to.equal(
'ease-in-out',
);
});

it('should stringify transition token cubicBezier properties to cubicBezier() CSS function', () => {
expect(
cubicBezierTransform({
value: {
duration: '200ms',
delay: '0ms',
timingFunction: [0.5, 0, 1, 1],
},
type: 'transition',
}),
).to.eql({
duration: '200ms',
delay: '0ms',
timingFunction: 'cubic-bezier(0.5, 0, 1, 1)',
});
expect(
cubicBezierTransform({
value: {
duration: '200ms',
delay: '0ms',
timingFunction: 'ease-in-out',
},
type: 'transition',
}),
).to.eql({
duration: '200ms',
delay: '0ms',
timingFunction: 'ease-in-out',
});

expect(
cubicBezierTransform({
value: {
duration: '200ms',
delay: '0ms',
},
type: 'transition',
}),
).to.eql({
duration: '200ms',
delay: '0ms',
});
});
});

Expand Down Expand Up @@ -1118,28 +1211,6 @@ describe('common', () => {
expect(typographyTransform({})).to.equal('16px sans-serif');
expect(typographyTransform({}, { basePxFontSize: 12 })).to.equal('12px sans-serif');
});

it('sets quotes around fontFamily if it has white-spaces in name', () => {
expect(
typographyTransform({
fontWeight: 300,
fontSize: '20px',
lineHeight: '1.5',
fontFamily: 'Arial Narrow, Arial, sans-serif',
}),
).to.equal("300 20px/1.5 'Arial Narrow', Arial, sans-serif");
});

it('handles array fontFamily values', () => {
expect(
typographyTransform({
fontWeight: 300,
fontSize: '20px',
lineHeight: '1.5',
fontFamily: ['Arial Narrow', 'Arial', 'sans-serif'],
}),
).to.equal("300 20px/1.5 'Arial Narrow', Arial, sans-serif");
});
});

// https://design-tokens.github.io/community-group/format/#border
Expand Down Expand Up @@ -1170,6 +1241,10 @@ describe('common', () => {
}),
).to.equal('5px dashed #000000');
});

it('allows every property to be optional', () => {
expect(borderTransform({})).to.equal('none');
});
});

describe('strokeStyle/css/shorthand', () => {
Expand Down Expand Up @@ -1197,7 +1272,7 @@ describe('common', () => {
transitionTransform({
duration: '200ms',
delay: '0ms',
timingFunction: [0.5, 0, 1, 1],
timingFunction: 'cubic-bezier(0.5, 0, 1, 1)',
}),
).to.equal('200ms cubic-bezier(0.5, 0, 1, 1) 0ms');

Expand Down
4 changes: 2 additions & 2 deletions __tests__/exportPlatform.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -651,7 +651,7 @@ Use log.verbosity "verbose" or use CLI option --verbose for more details.
},
platforms: {
css: {
transforms: ['transition/css/shorthand'],
transforms: ['cubicBezier/css', 'transition/css/shorthand'],
},
},
});
Expand All @@ -678,7 +678,7 @@ Use log.verbosity "verbose" or use CLI option --verbose for more details.
},
platforms: {
css: {
transforms: ['transition/css/shorthand'],
transforms: ['cubicBezier/css', 'transition/css/shorthand'],
},
},
});
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -519,12 +519,13 @@ Assumes a time in miliseconds and transforms it into a decimal
### fontFamily/css

Transforms `fontFamily` type token (which can be an array) into a CSS string, putting single quotes around font names that contain spaces where necessary.
Also handles the `fontFamily` property inside `typography` type object-values.

[DTCG definition](https://design-tokens.github.io/community-group/format/#font-family)

```css
/**
* Matches: token.type === 'fontFamily'
* Matches: token.type === 'fontFamily' || token.type === 'typography'
* Returns:
*/
:root {
Expand All @@ -537,12 +538,13 @@ Transforms `fontFamily` type token (which can be an array) into a CSS string, pu
### cubicBezier/css

Transforms `cubicBezier` type token into a CSS string, using the CSS `cubic-bezier` function.
Also handles the `timingFunction` property inside `transition` type object-values.

[DTCG definition](https://design-tokens.github.io/community-group/format/#cubic-bezier)

```css
/**
* Matches: token.type === 'cubicBezier'
* Matches: token.type === 'cubicBezier' || token.type === 'transition'
* Returns:
*/
:root {
Expand Down
Loading

0 comments on commit bc77590

Please sign in to comment.