0
Fork 0
mirror of https://github.com/penpot/penpot-plugins.git synced 2025-01-23 07:08:47 -05:00
penpot-plugins/docs/create-plugin.md

109 lines
3.3 KiB
Markdown
Raw Normal View History

2024-03-27 13:57:02 +01:00
# Creating a Plugin
2024-03-12 07:48:02 +01:00
2024-06-19 14:15:23 +02:00
This guide walks you through the steps to create a plugin for our platform. You'll start by setting up the basic structure, configuring necessary files, and then running a local server to preview your plugin.
If you prefer to create the plugin with angular, there's also a [Creating a Plugin (angular)](./create-angular-plugin.md).
2024-10-25 12:05:02 +02:00
Keep in mind that this guide is for creating a plugin **inside `penpot-plugins` monorepo**. If you want to create a plugin outside our environment you can check the [Penpot Plugin Starter Template](https://github.com/penpot/penpot-plugin-starter-template) or the documentation at [Create a Plugin](https://help.penpot.app/plugins/create-a-plugin/).
2024-06-19 14:15:23 +02:00
Let's dive in.
2024-03-12 07:48:02 +01:00
2024-03-27 13:57:02 +01:00
### Step 1: Initialize the Plugin
First, you need to create the scaffolding for your plugin. Use the following command, replacing `example-plugin` with the name of your plugin:
```sh
2024-02-06 12:16:28 +01:00
npx nx g @nx/web:application example-plugin --directory=apps/example-plugin
2024-03-12 07:48:02 +01:00
```
2024-02-06 12:16:28 +01:00
2024-07-10 11:49:02 +02:00
### Step 2: Migrate eslint to ESM
Replace `module.exports = [` with `export default [` and const `baseConfig = require('../../eslint.base.config.js');` with `import baseConfig from '../../eslint.config.js';`.
### Step 3: Configure the Manifest
2024-03-27 13:57:02 +01:00
Next, create a `manifest.json` file inside the `/public` directory. This file is crucial as it defines key properties of your plugin, including permissions and the entry point script.
2024-02-06 12:16:28 +01:00
```json
{
2024-03-27 13:57:02 +01:00
"name": "Example Plugin",
2024-05-30 09:33:05 +02:00
"host": "http://localhost:4201",
"code": "/plugin.js",
"icon": "/icon.png",
2024-07-02 10:55:49 +02:00
"permissions": [
"content:write",
"library:write",
"user:read",
"comment:read",
"allow:downloads"
2024-07-02 10:55:49 +02:00
]
2024-02-06 12:16:28 +01:00
}
```
2024-07-10 11:49:02 +02:00
### Step 4: Update Vite Configuration
2024-02-06 12:16:28 +01:00
2024-03-27 13:57:02 +01:00
Now, add the following configuration to your `vite.config.ts` to specify the entry points for the build process:
```typescript
2024-02-06 12:16:28 +01:00
build: {
rollupOptions: {
input: {
plugin: 'src/plugin.ts',
index: './index.html',
},
output: {
entryFileNames: '[name].js',
},
},
}
```
2024-07-10 11:49:02 +02:00
### Step 5: Modify TypeScript Configuration
2024-03-27 13:57:02 +01:00
Update your `tsconfig.app.json` to include the necessary TypeScript files for your plugin:
2024-02-27 14:50:38 +01:00
```json
2024-03-27 13:57:02 +01:00
{
"include": ["src/**/*.ts", "../../libs/plugin-types/index.d.ts"]
}
2024-02-27 14:50:38 +01:00
```
2024-07-10 11:49:02 +02:00
### Step 6: Run a Static Server
2024-02-06 12:16:28 +01:00
2024-03-27 13:57:02 +01:00
To preview your plugin, start a static server by running:
```sh
npx nx run example-plugin:build --watch & npx nx run example-plugin:preview
2024-03-12 07:48:02 +01:00
```
2024-07-10 11:49:02 +02:00
### Step 7: Add TS parser to eslint
2024-06-12 14:30:32 +02:00
Add these options to the end of the `eslint.config.js` file to allow linting with type information:
```js
{
languageOptions: {
parserOptions: {
project: './tsconfig.*?.json',
tsconfigRootDir: import.meta.dirname,
},
},
},
```
2024-07-10 11:49:02 +02:00
### Step 8: Load the Plugin in Penpot
2024-03-27 13:57:02 +01:00
2024-06-19 14:15:23 +02:00
To load your plugin into Penpot you can use the shortcut `Ctrl + Alt + P` to directly open the Plugin manager modal. There you need to provide the plugin's manifest URL (example: `http://plugin.example/manifest.json`) for the installation. If there's no issues the plugin will be installed and then you would be able to open it whenever you like.
2024-02-06 12:16:28 +01:00
2024-06-19 14:15:23 +02:00
You can also open the Plugin manager modal via:
2024-03-12 07:48:02 +01:00
2024-06-19 14:15:23 +02:00
- Menu
2024-03-27 13:57:02 +01:00
2024-06-19 14:15:23 +02:00
![Penpot's menu image](./images/plugin-menu.png)
2024-03-27 13:57:02 +01:00
2024-06-19 14:15:23 +02:00
### Learn More About Plugin Development
2024-03-27 13:57:02 +01:00
2024-06-19 14:15:23 +02:00
For more detailed information on plugin development, check out our guides:
2024-03-12 07:48:02 +01:00
2024-06-19 14:15:23 +02:00
- [Create API Documentation](./create-api.md)