Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pavellaptev/json-to-figma
An easy way to populate Figma layers with JSON
https://github.com/pavellaptev/json-to-figma
figma figma-plugin figma-plugins json json-figma
Last synced: about 1 month ago
JSON representation
An easy way to populate Figma layers with JSON
- Host: GitHub
- URL: https://github.com/pavellaptev/json-to-figma
- Owner: PavelLaptev
- License: mit
- Created: 2020-02-23T20:53:24.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2023-05-26T23:11:44.000Z (over 1 year ago)
- Last Synced: 2024-12-19T05:06:57.127Z (about 1 month ago)
- Topics: figma, figma-plugin, figma-plugins, json, json-figma
- Language: TypeScript
- Homepage:
- Size: 5.96 MB
- Stars: 142
- Watchers: 3
- Forks: 40
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# JSON to Figma (Not Maintained)
## Notice: This plugin is no longer maintained
Thank you for your interest in the JSON to Figma plugin. As of now, this plugin has become a paid plugin available on [the Figma Community](https://www.figma.com/community/plugin/789839703871161985/JSON-to-Figma). Due to this change, this repository will no longer be updated.
---
##### An easy way to use real data in Figma.
The plugin can parse local or JSON files from a URL link. You can populate any layers with text or images.
---
### Get the plugin
##### π₯ [figma.com/community/plugin/789839703871161985/JSON-to-Figma](https://www.figma.com/community/plugin/789839703871161985/JSON-to-Figma)
---
### π‘ Features:
- Load **local** files and fetch **from URL**
- Fetch images
- Supported image formats: **JPG, PNG, GIF, WEBP, SVG**
- Parsing JSON files with **any amount of nested levels**
- **Flexible** keys selection
- **Invert** selected keys
- Populate **in random order**
- Select any **ranges** from JSON file
- the **"skip" rule** for layers you won't populate
- Handle `null` values---
### Youtube demo
##### π₯ [youtu.be/7CKYdDfLFDY](https://youtu.be/J9Hu2hNSWvE)
---
## π How to Use
All you need is a [proper JSON](#-valid-json-structure). The plugin will parse show all available keys from the JSON including nested layers.
1. Load a JSON file localy or copy a link and the click on the "From Cipboard link" button.
2. Make sure layers you want to populate have the same names as in the JSON file. For example β if you see a key "user.name" key in the plugin the layer name also should be "user.name".
3. Select layers with items you want to populate. You can select group or frames with these layers, no need to select layers dirictly or manualy, the plugin will find them by their names.
4. Select keys you want to use for population.
5. Press "Populate selected" button---
### π€ Features
**`Range seection`** β If you want to select a certain range from a JSON, you can do it like this β1-10β, β1, 5, 20β, or combine them β1-10, 21, 50-340β β it means that the plugin will take JSON objects from 1 to 10, 21 and from 50 to 340 and combine them into one new array. Then you can also **save filtered array**.
**`Skip marked layers`** β if you want to skip layers, groups or frames β exclude them from the list, then you can use the βSkip marked layersβ option. Just select layers and press βSkip selectedβ. You can also clean marked layers or add the marker manually.
**`Random order`** β If you switch it on all items will be filled in a random order. By default, all your layers will be filled in order.
**`Image URLs recognition`** β The plugin will automaticly recognise values from a JSON that end with .JPG, .PNG, .GIF or .WEBP as images. if you name a shape or a frame with the name of the key β the pllugin wil fetch the image by URL and add it as a fill.
---
### β Valid JSON structure
The JSON structure for the file should look like an array of objects.
```json
[
{
"id": 1,
"name": "Shannah Judgkins",
"job": "Database Administrator II",
"image": "https://robohash.org/suntautvoluptatem.jpg?size=500x500&set=set1"
},
{
"id": 2,
"name": "Silvester Hallwell",
"job": "Data Coordiator",
"image": "https://robohash.org/rerumautemenim.jpg?size=500x500&set=set1"
}
]
```---
### π Services to generate JSON data
You can download try different JSON samples [from this repo](./json-test-files).
Or you can use on of these services:
- [mockaroo.com](https://www.mockaroo.com/)
- [next.json-generator.com](https://next.json-generator.com/EyLps-PPO?fbclid=IwAR0WGNKJMclqcS6qwRHj-NXOyF52BjQYJp9osgeWRmN2iCGZ47awnDDLhmI)
- [jsonplaceholder.typicode.com](https://jsonplaceholder.typicode.com/)