#token #design #serialization #css #reference #shadow #figtok

figtok_tokens

Utility for handling different token types for Figtok

1 unstable release

0.1.0 Feb 17, 2024

#1368 in Encoding


Used in figtok

MIT license

53KB
1K SLoC

Figtok/Tokens

This crate is responsible for defining the core structs used to define design tokens, the structures we use to store, retrieve and serialize tokens into CSS.

TokenDefinition

The TokenDefinition struct is constructed via serde. Our raw data is deserialized directly into TokenDefinition<T> depending on the underlying type of token. So far we have three:

  • Standard
  • Composition
  • Shadow

Standard Tokens are simple objects whose value is a String stored under token.value

Composition Tokens are objects whose value is a nested serde::Value. These nested values can contian any number of CSS properties, that should all be applied at once (i.e. as a single token, but containing multiple style properties) - because of this we serialize them slightly differently, producing a CSS Class definition rather than a CSS Variable so that the implementing application can apply all of the styles at once. This also has the benefit of allowing inner values to reference other tokens. When serializing each inner value is treated similar to a standard token where we unfurl any references to other tokens.

Shadow Tokens are defined similarly to composition tokens, where the value is a nested object - however, with shadows there are pre-defined set of inner properties that come together to create a box-shadow: [X] [Y] [BLUR] [SPREAD] [COLOR] because of this we deserialize similarly to composition tokens, but serialize more similarly to standard tokens, using the inner properties of the shadow token to produce a single value.

Token

The Token enum is responsible for providing a generic API over the top of our TokenDefinition<T>.

The token enum stores a TokenDefinition<T> and exposes some getters for retrieving the properties of the token. As we iterate through our token sets to serialize, we can use these getters to retrieve the name, type, etc. and also the value - with the additional magic that when fetching the Token.value() instead of directly accessing TokenDefinition<T>.value figtok will enrich the value to unfurl any references to other tokens.

TokenSet

TokenSets are simply a storage mechanism for keeping tokens that we're defined together, together. These sets can either be all serialized as individual files, or alternatively, if using the Themes feature of Figma Token Studio, as Figtok iterates through the themes it will only include the token sets relevant to that theme.

TokenStore

TokenStore is a trait that is implemented by FigTok itself that adds functionality for retrieving tokens, and enriching their values. The implementing sturct can store these tokens however it likes, as long as these methods are implemented to create compatability with the structs & systems outlined above.

TODO

  • Re-instate JSON serialization?

Dependencies

~3.5–5.5MB
~96K SLoC