Write Your First Plugin

This guide will walk you through creating a block plugin that can be used in pages from scratch, helping you understand the basic structure and development workflow of NocoBase plugins.

Prerequisites

Before getting started, make sure you have installed NocoBase. If not, you can refer to:

Once installation is complete, you can get started.

Step 1: Create Plugin Skeleton via CLI

Execute the following command in the repository root directory to quickly generate an empty plugin:

yarn pm create @my-project/plugin-hello

After the command runs successfully, it will generate basic files in the packages/plugins/@my-project/plugin-hello directory. The default structure is as follows:

├─ /packages/plugins/@my-project/plugin-hello
  ├─ package.json
  ├─ README.md
  ├─ client-v2.d.ts
  ├─ client-v2.js
  ├─ server.d.ts
  ├─ server.js
  └─ src
     ├─ index.ts                 # Default export server-side plugin
     ├─ client-v2                 # Client-side code location
  ├─ index.tsx             # Default exported client-side plugin class
  ├─ plugin.tsx            # Plugin entry (extends @nocobase/client-v2 Plugin)
  ├─ models                # Optional: frontend models (such as flow nodes)
  └─ index.ts
  └─ utils
     ├─ index.ts
     └─ useT.ts
     ├─ server                   # Server-side code location
  ├─ index.ts              # Default exported server-side plugin class
  ├─ plugin.ts             # Plugin entry (extends @nocobase/server Plugin)
  ├─ collections           # Optional: server-side collections
  ├─ migrations            # Optional: data migrations
  └─ utils
     └─ index.ts
     ├─ utils
  ├─ index.ts
  └─ tExpr.ts
     └─ locale                   # Optional: multi-language
        ├─ en-US.json
        └─ zh-CN.json

After creation, you can access the plugin manager page in your browser (default URL: http://localhost:13000/admin/settings/plugin-manager) to confirm whether the plugin appears in the list.

Step 2: Implement a Simple Client Block

Next, we'll add a custom block model to the plugin to display a welcome message.

  1. Create a new block model file client-v2/models/HelloBlockModel.tsx:
import { BlockModel } from '@nocobase/client-v2';
import React from 'react';
import { tExpr } from '../utils';

export class HelloBlockModel extends BlockModel {
  renderComponent() {
    return (
      <div>
        <h1>Hello, NocoBase!</h1>
        <p>This is a simple block rendered by HelloBlockModel.</p>
      </div>
    );
  }
}

HelloBlockModel.define({
  label: tExpr('Hello block'),
});
  1. Register the block model. Edit client-v2/models/index.ts to export the new model for frontend runtime loading:
import { ModelConstructor } from '@nocobase/flow-engine';
import { HelloBlockModel } from './HelloBlockModel';

export default {
  HelloBlockModel,
} as Record<string, ModelConstructor>;

After saving the code, if you're running a development script, you should see hot-reload logs in the terminal output.

Step 3: Activate and Test the Plugin

You can enable the plugin via command line or interface:

  • Command Line

    yarn pm enable @my-project/plugin-hello
  • Management Interface: Access the plugin manager, find @my-project/plugin-hello, and click "Activate".

After activation, create a new "Modern page (v2)" page. When adding blocks, you'll see "Hello block". Insert it into the page to see the welcome content you just wrote.

20250928174529

Make a Plugin Preset or Built-in by Default (Optional)

The steps above describe manually enabling a single plugin. If you are maintaining your own NocoBase application and want certain plugins to be automatically ready after running nocobase install (first-time installation) or nocobase upgrade (upgrade), you can use two environment variables to control a plugin's default state:

  • APPEND_PRESET_LOCAL_PLUGINS (append preset local plugins) — Adds the plugin to the preset local plugin list. After installation it appears in the Plugin Manager but is not activated by default; you need to enable it manually.
  • APPEND_PRESET_BUILT_IN_PLUGINS (append built-in plugins) — Adds the plugin to the built-in plugin list. It is automatically activated on installation and, as a built-in plugin, cannot be disabled or deleted from the Plugin Manager.

The value for both variables is the plugin package name (the name field in package.json); separate multiple plugins with commas. Configure them in .env like this:

# Preset: appears in the Plugin Manager list but is not activated automatically
APPEND_PRESET_LOCAL_PLUGINS=@my-project/plugin-hello,@my-project/plugin-hello-world

# Built-in: automatically installed and activated, and cannot be disabled from the UI
APPEND_PRESET_BUILT_IN_PLUGINS=@my-project/plugin-hello,@my-project/plugin-hello-world

For day-to-day local development and debugging, yarn pm enable (described above) is usually sufficient. These two variables are better suited for "out-of-the-box" distribution scenarios — for example, when you are shipping a NocoBase application bundled with a fixed set of plugins and want those plugins to be ready immediately after initialization.

Note
  • The plugin must already be downloaded locally and resolvable in node_modules. See Project Structure for details.
  • After configuring, you need to re-run nocobase install or nocobase upgrade for the changes to take effect.
  • For the full list of environment variable options, see Environment Variables.

Step 4: Build and Package

When you're ready to distribute the plugin to other environments, you need to build and package it first:

yarn build @my-project/plugin-hello --tar
# Or execute in two steps
yarn build @my-project/plugin-hello
yarn nocobase tar @my-project/plugin-hello
Tip

If the plugin is created in a source code repository, the first build will trigger a full repository type check, which may take some time. It's recommended to ensure dependencies are installed and the repository is in a buildable state.

After the build completes, the package file is located at storage/tar/@my-project/plugin-hello.tar.gz by default.

Tip

It's recommended to write test cases to verify core logic before publishing a plugin. NocoBase provides a complete server-side testing toolchain. See Test for details.

Step 5: Upload to Other NocoBase Applications

Upload and extract the package file to the target application's ./storage/plugins directory. For detailed steps, see Install and Upgrade Plugins.