@oscarotero/designtokens
v0.1.0
Published
Node package to parse and manipulate design tokens following the [DTCG](https://www.designtokens.org/) format.
Downloads
3
Maintainers
Readme
Design Tokens
Deno and Node library to parse, manipulate and transform tokens format as Design Tokens Community Group specifications.
Usage
import parse from "designtokens";
import json_tokens from "./my-json-with-tokens.json" assert { type: "json" };
const tokens = parse(json_tokens);
// Get a token
const mainColor = tokens.get("colors.main");
console.log(mainColor.value); // Get the value
mainColor.value = "#112233"; // Change the value
// Manipulate tokens
tokens.all.forEach((token) => {
if (token.type === "color") {
token.value = editColor(token.value);
}
});
// Export to JSON or stringifyed JSON
const json = tokens.toJson();
const txt = tokens.toString();
Alias
The spec has the concept of aliases as a way to reuse the values. This library supports aliases automatically:
{
"group name": {
"token name": {
"$value": 1234,
"$type": "number"
}
},
"alias name": {
"$value": "{group name.token name}"
}
}
const tokens = parse(json_tokens);
const alias = tokens.get("alias name");
alias.value; // resolved value: 1234
alias.$value; // RAW value: "{group name.token name}"
alias.type; // resolved type: number
alias.$type; // RAW type: undefined
Import from Style Dictionary
You can import tokens from the Style Dictionary format by setting the input format in the second argument.
import parse from "designtokens";
import style_dictionary_tokens from "./my-json-with-tokens.json" assert {
type: "json",
};
const tokens = parse(style_dictionary_tokens, "style-dictionary");