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

[Feature]: ts/resolveMath wrapInCalc option for CSS + outputReferences #203

Open
1 task
jorenbroekema opened this issue Oct 5, 2023 · 0 comments
Open
1 task
Labels
enhancement New feature or request

Comments

@jorenbroekema
Copy link
Member

jorenbroekema commented Oct 5, 2023

What feature would you like?

Input:

{
  "multiplier": {
    "value": 4,
    "type": "sizing"
  },
  "spacer": {
    "value": "{multiplier} * 8px"
    "type": "spacing"
  }
}

Current output:

:root {
  --multiplier: 4;
  --spacer: var(--multiplier) * 8px;
}

Preferred output:

:root {
  --multiplier: 4;
  --spacer: calc(var(--multiplier) * 8px);
}

How?

ts/resolveMath transform could accept an option "wrapInCSSCalc" or something along those lines which can be used in conjunction with StyleDictionary's outputReferences feature, so instead of resolving the math statement, it will just wrap it inside calc(statement).

See also: amzn/style-dictionary#1002
When using outputReferences currently in Style-Dictionary v4 prerelease, there is a fix for it to work better with transitive value transforms (like ts/resolveMath), tokens using math statements with references inside them will be resolved and calculated, but then actually get replaced by token original value (with the reference being replaced by var(--ref-token-name)) by outputReferences. This is an improvement over Style-Dictionary v3 outputReferences, but still not that useful in the final output without having a calc() wrapped around it to resolve the math through CSS.

Would you be available to contribute this feature?

  • Yes, I would like to contribute this
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

1 participant