Figma Variables to Dart
Bring your Figma design system and Flutter app implementation closer together by generating Dart code directly from Figma API.
Which problem are we trying to solve?
- Figma codegen plugins for Flutter/Dart are limited
- There's manual interaction with Figma UI required and it takes time on bigger projects
- No easy way to detect which variables changed/updated without manual inspection
Installation
dev_dependencies:
  figma_vars_to_dart: ^0.1.0 
or
flutter pub add figma_vars_to_dart --dev
Commands
Usage
Create the token
In order to interact with Figma API you will need a personal access token. To create this token you can follow this figma tutorial.
Figma Variables
Make sure your Figma project uses variables.
Sample inputs for the demo purposes
 
  
Run the command
dart pub run figma_vars_to_dart generate \
	 --token $FIGMA_TOKEN \
	 --fileId $YOUR_FIGMA_FILE_ID \ # you can find this string value in your file URL
	 --dartOutputFolder lib/shared/ui_constants \
	 --jsonOutputFile vars.json 
Use the code
Generated files
color_primitives.dart
import 'package:flutter/widgets.dart';
class ColorPrimitives {
  final Color white;
  final Color pink;
  final Color green;
  final Color black;
  final Color blue;
  ColorPrimitives({
    required this.white,
    required this.pink,
    required this.green,
    required this.black,
    required this.blue,
  });
  factory ColorPrimitives.value() => ColorPrimitives(
        white: const Color(0xFFF2ECEC),
        pink: const Color(0xFFDD006A),
        green: const Color(0xFF8CC93E),
        black: const Color(0xFF2C2C2C),
        blue: const Color(0xFF3000F2),
      );
}
color_semantics.dart
import 'package:flutter/widgets.dart';
import 'ui_constants.dart';
class ColorSemantics {
  final Color background;
  final Color buttonPrimary;
  ColorSemantics({
    required this.background,
    required this.buttonPrimary,
  });
  factory ColorSemantics.light(ColorPrimitives colorPrimitives) =>
      ColorSemantics(
        background: colorPrimitives.white,
        buttonPrimary: colorPrimitives.blue,
      );
  factory ColorSemantics.dark(ColorPrimitives colorPrimitives) =>
      ColorSemantics(
        background: colorPrimitives.black,
        buttonPrimary: colorPrimitives.green,
      );
}
ui_constants.dart
export 'color_primitives.dart';
export 'color_semantics.dart';
You can use any state management you prefer to provide these values to your widgets.
Example
See the example for more information.
Downloading Images
To use the download-images feature, create sections for specific use cases. Each section name must follow the format "APP_ASSET_$section", where $section represents a specific use case. Then, add the images you want to download and convert them into components.
Sample for the demo purposes

Run the command
dart pub run figma_vars_to_dart download-images \
	 --token $FIGMA_TOKEN \
	 --fileId $YOUR_FIGMA_FILE_ID 
Arguments
| Argument | Type | Required | Default | Description | 
|---|---|---|---|---|
| --fileId | String | ✅ Yes | None | The Figma file ID, which can be found in the Figma file URL. | 
| --token | String | ✅ Yes | None | Your Figma personal access token for authentication. | 
| --outputFolder | String | ❌ No | assets | The folder where downloaded images will be stored. Defaults to assets/. | 
| --format | String | ❌ No | png | The format of the downloaded images. Allowed values: jpg,png,svg. | 
| --scale | String | ❌ No | 1.0,2.0,3.0 | The scales for downloaded images (comma-separated). Must be between 0.01 and 4.0. Note: If the format is svg, this argument is ignored and set to1.0. | 
| --section | String | ❌ No | APP_ASSET_ | Specify Figma sections to download (comma-separated). By default, all APP_ASSET_$sectionsections are considered. | 
| --force | Flag | ❌ No | false | Forces downloading the images even if they already exist. | 
Contributing
Contributions are welcome! If you encounter issues, have feature suggestions, or want to improve the package, feel free to open an issue or submit a pull request. Please read our Contribution Guidelines for more information.
License
This project is licensed under the MIT License.
Libraries
- commands/commands
- commands/download_images_from_args
- commands/generate_from_args
- services/code_generator/code_generator
- services/code_generator/code_generator_service
- services/code_generator/dart_keywords
- services/code_generator/formatter
- services/code_generator/int_ext
- services/code_generator/string_ext
- services/figma/figma
- services/figma/figma_entities
- services/figma/figma_service
- services/logger/logger
- services/logger/logger_service
- services/parser/code_entities
- services/parser/parser
- services/parser/parser_service
- services/services
- services/writer/write_task
- services/writer/writer
- services/writer/writer_service