Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/b3nnyl/figgo
π―ββοΈA cli tool makes your Figma and local design token stay in sync π―ββοΈ
https://github.com/b3nnyl/figgo
cli design-system figma ui
Last synced: 2 days ago
JSON representation
π―ββοΈA cli tool makes your Figma and local design token stay in sync π―ββοΈ
- Host: GitHub
- URL: https://github.com/b3nnyl/figgo
- Owner: B3nnyL
- License: mit
- Created: 2019-01-24T02:53:01.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2023-01-06T04:52:10.000Z (about 2 years ago)
- Last Synced: 2025-01-20T10:07:25.023Z (2 days ago)
- Topics: cli, design-system, figma, ui
- Language: TypeScript
- Homepage: https://github.com/B3nnyL/figgo
- Size: 1.35 MB
- Stars: 309
- Watchers: 8
- Forks: 15
- Open Issues: 15
-
Metadata Files:
- Readme: readme.md
- License: LICENSE
Awesome Lists containing this project
README
Figgo
A CLI tool make your design tokens always stay up to date with your Figma design styleguide
![img](https://img.shields.io/travis/B3nnyL/figgo/master.svg)
![img](assets/cover.png)
## Install Figgo
`npm i figgo -g`
## Figma Guide
- Create three frames named as `Typography`, `Palette` and `Space` in your figma file.
- Spread out your typography, color and spacing examples to the frames. Follow this [figma example](https://www.figma.com/file/ULXceywc0RjE0MFYNgOiZDrl/Figgo) for the best outcomes.
- Grab the figma file's id.
- Generate your personal token at `account setting` and grab it.## Terminal Guide
Assume you have already installed Figgo...
### Global setup
- Run `figgo --init`, answer a few setup questions where you will leave file id and personal token with Figgo. All configuration will save to `~/.figgo`. **_Note: output directory needs to be absolute path._**
- Tied your belt and type `figgo --sync`, let tokens store in the location you wish.
- You may run `figgo --sync board_name` to update tokens selectively.### Local setup
- Create `figgo.json` file under your project directory.
```json
{
"boards": [
{
"boardName": "your board name",
"id": "figma id",
"outputDir": "output directory (this can be a path relative to your project)",
"outputFormat": "js or scss",
"token": "your figma personal token"
},
{
...
}
]
}
```- Run `figgo --sync` and all tokens will store in the path you wish or update selectively via appending board name.
## Basic CLI Usage
```shell
How to use
$ figgo [ ...]
Options
--init, -i Setup figma board and store configurations to global config files
--sync, -s Sync tokens based on (global/local) config files
--edit, -e Edit board information (not ready yet)
--list, -l List boards from global config files
--remove, -r Remove board from global config files
--help, -h Show help message
--version, -v Show installed version
Examples
$ figgo --init
$ figgo --init board_name board_id output_absolute_path output_format(js|scss) figma_token
$ figgo --edit board_name (not ready yet)
$ figgo --list
$ figgo --sync
$ figgo --sync board_name
$ figgo --remove board_name
$ figgo --help
$ figgo --version
```### Sync Token
![url](https://i.imgur.com/wfWei0q.gif)
## Manual configuration
Edit setup configuration from `config.js` in `~/.figgo` folder. You can also manually add Figma board through editting this file.
## Dev Guide
- Installation
`yarn install`
- development
`yarn start [options]`
- test
`yarn test`
- build
`yarn build`## Changelogs
- 0.1.1 π Alive
- 0.1.2 βοΈ Readme
- 0.1.3 π Fix minor issues
- 0.1.5 π€ Better UX
- 0.1.8 π€ Project figgo.json is supported
- 0.1.11 π€ Fix minor issues and improve UX- 0.2 π§©Support css variable, fixed test and CI
## TODOs
- [x] CLI listing board information
- [x] CLI specify board sync
- [x] js output supports
- [x] css variable support
- [ ] Edit Figma board info from CLI
- [x] Well-formatted and styled output in terminal
- [ ] More screenshots and documentation## License
MIT
## Credits
[Figma](https://www.figma.com)