Skip to content

Commit

Permalink
Merge pull request #126 from tokens-studio/consider-empty-string
Browse files Browse the repository at this point in the history
fix: consider empty string props in typo/border/shadow
  • Loading branch information
jorenbroekema authored May 17, 2023
2 parents 0255ee2 + ce69ada commit f29fa4c
Show file tree
Hide file tree
Showing 9 changed files with 44 additions and 23 deletions.
5 changes: 5 additions & 0 deletions .changeset/poor-apples-fetch.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
'@tokens-studio/sd-transforms': patch
---

Consider that properties can also be empty string, which is especially common if the typography/border/shadow tokens are coming from Tokens Studio.
12 changes: 8 additions & 4 deletions src/css/transformBorder.ts
Original file line number Diff line number Diff line change
@@ -1,20 +1,24 @@
import { checkAndEvaluateMath } from '../checkAndEvaluateMath.js';
import { transformDimension } from '../transformDimension.js';
import { transformHEXRGBaForCSS } from './transformHEXRGBa.js';
import { isNothing } from '../utils/is-nothing.js';

/**
* Helper: Transforms border object to border shorthand
* This currently works fine if every value uses an alias,
* but if any one of these use a raw value, it will not be transformed.
*/
export function transformBorderForCSS(
border: Record<string, string> | undefined | string,
border: Record<string, string | undefined> | undefined | string,
): string | undefined {
if (typeof border !== 'object') {
return border;
}
const { color, width, style } = border;
return `${transformDimension(checkAndEvaluateMath(width)) ?? ''} ${style ?? ''} ${
transformHEXRGBaForCSS(color) ?? ''
let { color, width } = border;
const { style } = border;
width = transformDimension(checkAndEvaluateMath(width));
color = transformHEXRGBaForCSS(color);
return `${isNothing(width) ? '' : width} ${isNothing(style) ? '' : style} ${
isNothing(color) ? '' : color
}`.trim();
}
19 changes: 11 additions & 8 deletions src/css/transformShadow.ts
Original file line number Diff line number Diff line change
@@ -1,25 +1,28 @@
import { checkAndEvaluateMath } from '../checkAndEvaluateMath.js';
import { transformDimension } from '../transformDimension.js';
import { transformHEXRGBaForCSS } from './transformHEXRGBa.js';
import { isNothing } from '../utils/is-nothing.js';

/**
* Helper: Transforms boxShadow object to shadow shorthand
* This currently works fine if every value uses an alias,
* but if any one of these use a raw value, it will not be transformed.
*/
export function transformShadowForCSS(
shadow: Record<string, string> | undefined | string,
shadow: Record<string, string | undefined> | undefined | string,
): string | undefined {
if (typeof shadow !== 'object') {
return shadow;
}
let { x, y, blur, spread } = shadow;
const { color, type } = shadow;
x = transformDimension(checkAndEvaluateMath(x)) as string;
y = transformDimension(checkAndEvaluateMath(y)) as string;
blur = transformDimension(checkAndEvaluateMath(blur)) as string;
spread = transformDimension(checkAndEvaluateMath(spread)) as string;
return `${type === 'innerShadow' ? 'inset ' : ''}${x ?? 0} ${y ?? 0} ${blur ?? 0}${
spread == null ? ' ' : ` ${spread} `
}${transformHEXRGBaForCSS(color) ?? 'rgba(0, 0, 0, 1)'}`.trim();
x = transformDimension(checkAndEvaluateMath(x));
y = transformDimension(checkAndEvaluateMath(y));
blur = transformDimension(checkAndEvaluateMath(blur));
spread = transformDimension(checkAndEvaluateMath(spread));
return `${type === 'innerShadow' ? 'inset ' : ''}${isNothing(x) ? 0 : x} ${
isNothing(y) ? 0 : y
} ${isNothing(blur) ? 0 : blur}${isNothing(spread) ? ' ' : ` ${spread} `}${
transformHEXRGBaForCSS(color) ?? 'rgba(0, 0, 0, 1)'
}`.trim();
}
15 changes: 8 additions & 7 deletions src/css/transformTypography.ts
Original file line number Diff line number Diff line change
@@ -1,25 +1,26 @@
import { transformDimension } from '../transformDimension.js';
import { transformFontWeights } from '../transformFontWeights.js';
import { checkAndEvaluateMath } from '../checkAndEvaluateMath.js';
import { isNothing } from '../utils/is-nothing.js';

/**
* Helper: Transforms typography object to typography shorthand for CSS
* This currently works fine if every value uses an alias, but if any one of these use a raw value, it will not be transformed.
* If you'd like to output all typography values, you'd rather need to return the typography properties itself
*/
export function transformTypographyForCSS(
value: Record<string, string> | undefined | string,
value: Record<string, string | undefined> | undefined | string,
): string | undefined {
if (typeof value !== 'object') {
return value;
}
const { fontFamily } = value;
let { fontWeight, fontSize, lineHeight } = value;
fontWeight = transformFontWeights(fontWeight) as string;
fontSize = transformDimension(checkAndEvaluateMath(fontSize)) as string;
lineHeight = checkAndEvaluateMath(lineHeight) as string;
fontWeight = transformFontWeights(fontWeight);
fontSize = transformDimension(checkAndEvaluateMath(fontSize));
lineHeight = checkAndEvaluateMath(lineHeight);

return `${fontWeight ?? 400} ${fontSize ?? '16px'}/${lineHeight ?? 1} ${
fontFamily ?? 'sans-serif'
}`;
return `${isNothing(fontWeight) ? 400 : fontWeight} ${isNothing(fontSize) ? '16px' : fontSize}/${
isNothing(lineHeight) ? 1 : lineHeight
} ${isNothing(fontFamily) ? 'sans-serif' : fontFamily}`;
}
3 changes: 2 additions & 1 deletion src/transformDimension.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,9 @@ export function transformDimension(value: string | undefined | number): string |
}

// Check if the value is numeric with isNaN, this supports string values as well
// Check if value is not empty string, since this is also not considered "NaN"
// Check if the value, when parsed (since it can also be number), does not equal 0
if (!isNaN(value as number) && parseFloat(value as string) !== 0) {
if (!isNaN(value as number) && value !== '' && parseFloat(value as string) !== 0) {
return `${value}px`;
}
return `${value}`;
Expand Down
6 changes: 6 additions & 0 deletions src/utils/is-nothing.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
export function isNothing(value: string | null | undefined): boolean {
if (value == null || value === '') {
return true;
}
return false;
}
1 change: 1 addition & 0 deletions test/spec/css/transformBorder.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ describe('transform border', () => {
expect(
transformBorderForCSS({
width: '5',
style: '',
}),
).to.equal('5px');

Expand Down
2 changes: 1 addition & 1 deletion test/spec/css/transformShadow.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ describe('transform shadow', () => {
it('provides empty string or 0 for missing properties', () => {
expect(transformShadowForCSS({})).to.equal('0 0 0 rgba(0, 0, 0, 1)');

expect(transformShadowForCSS({ x: '5' })).to.equal('5px 0 0 rgba(0, 0, 0, 1)');
expect(transformShadowForCSS({ x: '5', y: '' })).to.equal('5px 0 0 rgba(0, 0, 0, 1)');

expect(transformShadowForCSS({ spread: '5', color: 'rgba(#000000, 0.5)' })).to.equal(
'0 0 0 5px rgba(0, 0, 0, 0.5)',
Expand Down
4 changes: 2 additions & 2 deletions test/spec/css/transformTypographyForCSS.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -31,10 +31,10 @@ describe('transform typography', () => {
expect(
transformTypographyForCSS({
fontWeight: 'light',
fontSize: '20',
fontSize: '',
fontFamily: 'Arial',
}),
).to.equal('300 20px/1 Arial');
).to.equal('300 16px/1 Arial');

expect(transformTypographyForCSS({})).to.equal('400 16px/1 sans-serif');
});
Expand Down

0 comments on commit f29fa4c

Please sign in to comment.