Figstract bridges the process for maintaining design systems (in Figma) between frontend engineers and designers and helps automate mundane upkeep tasks.
This tool extracts the following design system tokens produced by designers in Figma:
- Assets (raster and vector assets like images and icons)
- Design system variables (booleans, numbers, strings, and colors)
And imports them in native formats for frontend engineers to use on:
- Web
- Android (natively, using Android SDKs)
- iOS (natively, using Apple / iOS SDKs)
Figstract comes with an out-of-the-box CLI, which includes options for filtering and extraction, but has been designed to be modular so engineers can compose their own CLIs or other tools based on Figstract's foundation.
Note
While Figstract is pre-release, some CLI options may change
Figstract uses the Figma REST API and has the following features:
- Concurrent and Parallel: Uses concurrency and multithreading to process Figma files at speed
- Multi-file: Operations can handle multiple Figma files in parallel
- Flexible filters: Manage included and excluded tokens
Figstract operations use a processing pipeline:
- Reading: Accessing Figma files
- Exporting: Extracting tokens
- Importing: Converting tokens
To create a runnable fat JAR, just run the following Gradle command:
./gradlew :cli:shadowJar
The compiled JAR will be located in cli/build/libs/cli-0.0.1-alpha01-all.jar
(make sure you use the .jar
with the name ending in -all
).
Run the following command to run Figstract and list the subcommands and options:
java -jar /path/to/cli.jar --help
The CLI can be configured with CLI args, or by supplying a [subcommandName].properties
file with the same keys as the arguments in the working directory (e.g. assets.properties
).
Figstract supports the following authentication mechanisms to accessing Figma:
- Personal Access Tokens (PATs). Refer to the Figma documentation and API reference for more info.
When generating credentials, ensure that the following scopes are configured.
Operation | Required scope |
---|---|
assets | File content |
variables | File content , Variables |
Caution
Ensure scopes are set to Read only
and tokens are refreshed regularly
Either one auth credential can be generated with all the scopes above, or specific auth credentials can be created for each subcommand.
Figstract uses kotlin-logging and Logback for logging, and logs errors to the console by default.
When using the CLI, the log level can be configured using the --logLevel
option (e.g.
--logLevel DEBUG
), or by configuring logback using environment variables (refer to https://logback.qos.ch/manual/configuration.html#configFileProperty).
TODO:
- supported output formats
- Web
- Android
- WEBP images automatically scaled in density buckets
- Android Vector Drawables which have been magenta-fied for tinting
- iOS
- Asset catalogs with scale support
- Asset format within figma files
- Composable pipeline for importing and converting assets
- JsonPath support
- Supports Stefan Goessner's JsonPath implementation using https://github.com/json-path/JsonPath
- JsonPath expressions are relative to each Canvas and should locate the required node. Refer to the Figma API Node reference
- Canvas and node filters will be applied, but parent node filters aren't supported for now
- Custom naming
Figstract can extract local variables from Figma files. All variable types (booleans, numbers, strings and colors) are supported.
All variable types will be outputted by default, but can be configured to be omitted completely.
All output formats use the variable collection's name as the file name. Variables will be first grouped by mode then by variable type within each variable collection's file. Colors can be configured to be outputted as either Hex or RGBA values (RGBA values are floats between 0 and 1 inclusive).
Note: Variable collection, mode and variable names will be sanitised to conform with platform / language conventions.
For web (or any platform), Figstract generates JSON files with the following format:
My Variable Collection.json
{
"My Mode": {
"booleans": {
"bool var 1": true,
"bool var 2": false
},
"numbers": {
"number var 1": 123.45,
"number var 2": -543.21
},
"strings": {
"string var 1": "Hello",
"string var 2": "World"
},
"colors": {
"color rgba var 1": {
"r": 0.1,
"g": 0.2,
"b": 0.3,
"a": 1.0
},
"color rgba var 2": {
"r": 1.0,
"g": 1.0,
"b": 1.0,
"a": 1.0
},
"color hex var 1": "0xFF19334C",
"color hex var 2": "0xFFFFFFFF"
}
}
}
Refer to JsonVariableDataWriter for the implementation.
Figstract generates an R-file-like Kotlin object with constants with the following format:
MyVariableCollection.kt
package your.pkg.here
import androidx.compose.ui.graphics.Color
import kotlin.Double
public object MyVariableCollection {
public object MyMode {
public object Booleans {
public val boolVar1: Boolean = true
public val boolVar2: Boolean = false
}
public object Numbers {
public val numberVar1: Double = 123.45
public val numberVar2: Double = -543.21
}
public object Strings {
public val stringVar1: String = "Hello"
public val stringVar2: String = "World"
}
public object Colors {
public val colorRgbaVar1: Color = Color(
red = 0.1f,
green = 0.2f,
blue = 0.3f,
alpha = 1.0f,
)
public val colorRgbaVar2: Color = Color(
red = 1.0f,
green = 1.0f,
blue = 1.0f,
alpha = 1.0f,
)
public val colorHexVar1: Color = Color(0xFF19334C)
public val colorHexVar2: Color = Color(0xFFFFFFFF)
}
}
}
The package must be specified when configuring this output.
Refer to AndroidComposeVariableDataWriter for the implementation.
Note
Coming soon
Note
Coming soon
TODO
- Shell wrapper
- Github action support
- Better error handling