Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/aarongarciah/figma-plugin-typescript-boilerplate
Figma plugin TypeScript boilerplate to start developing right away
https://github.com/aarongarciah/figma-plugin-typescript-boilerplate
editorconfig eslint figma figma-plugin jest plugin prettier stylelint typescript
Last synced: 3 months ago
JSON representation
Figma plugin TypeScript boilerplate to start developing right away
- Host: GitHub
- URL: https://github.com/aarongarciah/figma-plugin-typescript-boilerplate
- Owner: aarongarciah
- License: mit
- Created: 2019-12-10T20:08:55.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2023-03-14T17:34:14.000Z (almost 2 years ago)
- Last Synced: 2024-10-30T04:01:40.118Z (3 months ago)
- Topics: editorconfig, eslint, figma, figma-plugin, jest, plugin, prettier, stylelint, typescript
- Language: TypeScript
- Homepage:
- Size: 1.05 MB
- Stars: 55
- Watchers: 3
- Forks: 6
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
![Figma Plugin TypeScript Boilerplate](.github/cover.jpg)
**Figma plugin TypeScript boilerplate to start developing right away.**
[![Actions Status](https://github.com/aarongarciah/figma-plugin-typescript-boilerplate/workflows/CI/badge.svg)](https://github.com/aarongarciah/figma-plugin-typescript-boilerplate/actions)
[![code style: prettier](https://img.shields.io/badge/code_style-prettier-ff69b4.svg)](https://github.com/prettier/prettier)## Quick start
1. Get the boilerplate **choosing one** of these methods:
- Fork this repo.
- Execute these commands in your terminal:
```bash
mkdir my-plugin
cd my-plugin
npx degit https://github.com/aarongarciah/figma-plugin-typescript-boilerplate
```
- [Download the repo](https://github.com/aarongarciah/figma-plugin-typescript-boilerplate/archive/master.zip) and extract it into your empty plugin folder.2. Install dependencies
```bash
npm install
```3. Develop 😄
```bash
npm run dev
```> You'll need Node and npm installed to use this boilerplate. It has been tested in Node 12, 14, and 16.
## Development
To develop a Figma plugin you need to install the Figma [desktop app](https://www.figma.com/downloads/). Learn more in the [Figma Plugin docs](https://www.figma.com/plugin-docs/setup/).
### Available commands
#### Development
- `npm run dev` starts the watcher for changes. Modify the files under the `src` folder and the code will be compiled automatically. Then, go to the Figma app and run your development plugin.#### Production build
- `npm run build` generates the production build in the `dist` folder. Important: run this command before releaseing a new version of your plugin. Before generating the build, it checks TypeScript, JavaScript and CSS files for linting errors.#### Test
- `npm run test` runs tests via Jest. This script runs before `build`.
- `npm run test:watch` runs tests via Jest in watch mode.#### Lint
- `npm run lint` lint TypeScript and JavaScript files with ESLint and CSS with Stylelint.
- `npm run lint:fix` lint and apply automatic fixes to TypeScript, JavaScript and CSS files. This script runs before `build`.## What this boilerplate does for me?
> It's highly recommended to take a look at the [Figma plugin development docs](https://www.figma.com/plugin-docs/intro/) before developing a plugin.
>
> A plugin has [two parts](https://www.figma.com/plugin-docs/how-plugins-run/): a mandatory worker file (a JavaScript file which has access to the Figma document) and an optional UI (an HTML file).- Compiles TypeScript.
- Inlines JS and CSS code into the HTML for the UI. That's because the Figma plugin UI must be a unique HTML file and can't reference any other assets like CSS or JS with relative paths. You can load any external asset (e.g. a file hosted in a CDN) but not relative paths.
- Provides setup and config for: TypeScript, webpack, ESLint, Stylelint, Prettier, Jest, EditorConfig, etc.
- Lints and formats the code in a pre-commit hook.
- Provides boilerplate to send messages between the worker and the UI.
- Contains a helper to close the UI if you hit the ESC key outside of an input.
- Testing environment configured with Jest. Every test file under a `__tests__` folder or ending with `.spec.*` or `.test.*` will be picked up by Jest.
- Contains a GitHub action to run the `build` and `test` commands.---
## Having problems?
Take a look if someone already opened [a similar issue](https://github.com/aarongarciah/figma-plugin-boilerplate/issues?utf8=%E2%9C%93&q=is%3Aissue+sort%3Aupdated-desc+) or open a [new one](https://github.com/aarongarciah/figma-plugin-boilerplate/issues/new).
---
## Roadmap
- [ ] Add FAQ to README.
- [ ] Add bin executables to create templates via `npx`.---
## License
MIT
Made with ♥️ by [Aarón García Hervás](https://aarongarciah.com)