3.2 KiB
Creating a Plugin
This guide walks you through the steps to create an Angular plugin.
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:
npx nx g @nx/angular:app example-plugin --directory=apps/example-plugin --bundler=esbuild
Step 2: Configure the Manifest
Next, create a manifest.json
file inside the /src/assets
directory. This file is crucial as it defines key properties of your plugin, including permissions and the entry point script.
{
"name": "Example plugin",
"host": "http://localhost:4200",
"code": "/assets/plugin.js",
"icon": "/assets/icon.png",
"permissions": ["page:read", "file:read", "selection:read"]
}
Step 3: Update Project Configuration
Now, add the following configuration to your project.json
to compile the plugin.ts
file:
"tags": ["type:plugin"],
"targets": {
"buildPlugin": {
"executor": "@nx/esbuild:esbuild",
"outputs": [
"{options.outputPath}"
],
"options": {
"minify": true,
"outputPath": "apps/example-plugin/src/assets/",
"main": "apps/example-plugin/src/plugin.ts",
"tsConfig": "apps/example-plugin/tsconfig.plugin.json",
"generatePackageJson": false,
"format": [
"esm"
],
"deleteOutputPath": false
}
},
}
Also, update targets.build
with the following code to allow the use of Penpot styles.
"styles": [
"libs/plugins-styles/src/lib/styles.css",
"apps/example-plugin/src/styles.css"
],
"optimization": {
"scripts": true,
"styles": true,
"fonts": false
}
Step 4: Modify TypeScript Configuration
Create ``tsconfig.plugin.jsonnext to the
tsconfig.json`:
{
"extends": "./tsconfig.json",
"compilerOptions": {
"types": []
},
"files": ["src/plugin.ts"],
"include": ["../../libs/plugin-types/index.d.ts"]
}
Add the reference to the main tsconfig.json:
"references": [
{
"path": "./tsconfig.plugin.json"
}
],
Strep 5: Hello world plugin code
Create the file apps/example-plugin/src/plugin.ts
with the following code:
console.log('Hello Plugin');
Step 6: Run the plugin
Run this command:
npx nx run-many --targets=buildPlugin,serve --projects=example-plugin --watch
This will run two tasks: serve
, the usual Angular server, and buildPlugin
, which will compile the plugin.ts
file.
Step 6: Load the Plugin in Penpot
Finally, to load your plugin into Penpot, execute the following command in the browser's console devtools:
ɵloadPluginByUrl('http://localhost:4201/assets/manifest.json');
Learn More About Plugin Development
For more detailed information on plugin development, check out our guides:
Using a Starter Template
If you prefer to kickstart your plugin development, consider using the Penpot Plugin Starter Template. It's a template designed to streamline the creation process for Penpot plugins.