Skip to content

✒️ Lobe Editor - a modern, extensible rich text editor built on Meta's Lexical framework with dual-architecture design, featuring both a powerful kernel and React integration. Optimized for AI applications and chat interfaces.

License

Notifications You must be signed in to change notification settings

lobehub/lobe-editor

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

LobeHub Editor

A modern, extensible rich text editor built on Meta's Lexical framework with dual-architecture design, featuring both a powerful kernel and React integration. Optimized for AI applications and chat interfaces.


Changelog · Report Bug · Request Feature

Table of contents

TOC

✨ Features

  • 🎯 Dual Architecture - Both kernel-based API and React components for maximum flexibility
  • ⚛️ React-First - Built for React 19+ with modern hooks and patterns
  • 🔌 Rich Plugin Ecosystem - 10+ built-in plugins for comprehensive content editing
  • 💬 Chat Interface Ready - Pre-built chat input components with mention support
  • ⌨️ Slash Commands - Intuitive / and @ triggered menus for quick content insertion
  • 📝 Multiple Export Formats - JSON, Markdown, and plain text export capabilities
  • 🎨 Customizable UI - Antd-styled components with flexible theming
  • 🔗 File & Media Support - Native support for images, files, tables, and more
  • 🎯 TypeScript Native - Built with TypeScript for excellent developer experience
  • 📱 Modern Build System - Optimized with Vite, Dumi docs, and comprehensive testing

📦 Installation

To install @lobehub/editor, run the following command:

$ bun add @lobehub/editor
$ pnpm add @lobehub/editor

🚀 Quick Start

Basic Editor

The simplest way to get started with a fully-featured editor:

import {
  ReactCodeblockPlugin,
  ReactImagePlugin,
  ReactLinkPlugin,
  ReactListPlugin,
} from '@lobehub/editor';
import { Editor } from '@lobehub/editor/react';

export default function MyEditor() {
  const editorRef = Editor.useEditor();

  return (
    <Editor
      placeholder="Start typing..."
      editorRef={editorRef}
      plugins={[ReactListPlugin, ReactLinkPlugin, ReactImagePlugin, ReactCodeblockPlugin]}
      slashOption={{
        items: [
          {
            key: 'h1',
            label: 'Heading 1',
            onSelect: (editor) => {
              editor.dispatchCommand(INSERT_HEADING_COMMAND, { tag: 'h1' });
            },
          },
          // More slash commands...
        ],
      }}
      onChange={(editor) => {
        // Handle content changes
        const markdown = editor.getDocument('markdown');
        const json = editor.getDocument('json');
      }}
    />
  );
}

Advanced Usage with Plugins

Add more functionality with built-in plugins:

import {
  INSERT_FILE_COMMAND,
  INSERT_TABLE_COMMAND,
  ReactFilePlugin,
  ReactHRPlugin,
  ReactTablePlugin,
} from '@lobehub/editor';
import { Editor } from '@lobehub/editor/react';

export default function AdvancedEditor() {
  const editorRef = Editor.useEditor();

  return (
    <Editor
      editorRef={editorRef}
      plugins={[
        ReactTablePlugin,
        ReactHRPlugin,
        Editor.withProps(ReactFilePlugin, {
          handleUpload: async (file) => {
            // Handle file upload
            return { url: await uploadFile(file) };
          },
        }),
      ]}
      mentionOption={{
        items: async (search) => [
          {
            key: 'user1',
            label: 'John Doe',
            onSelect: (editor) => {
              editor.dispatchCommand(INSERT_MENTION_COMMAND, {
                label: 'John Doe',
                extra: { userId: 1 },
              });
            },
          },
        ],
      }}
    />
  );
}

Chat Input Component

Pre-built component optimized for chat interfaces:

import { ChatInput } from '@lobehub/editor/react';

export default function ChatApp() {
  return (
    <ChatInput
      placeholder="Type a message..."
      onSend={(content) => {
        // Handle message send
        console.log('Message:', content);
      }}
      enabledFeatures={['mention', 'upload', 'codeblock']}
    />
  );
}

Editor Kernel API

For advanced use cases, access the underlying kernel directly:

import { IEditor, createEditor } from '@lobehub/editor';

// Create editor instance
const editor: IEditor = createEditor();

// Register plugins
editor.registerPlugin(SomePlugin, { config: 'value' });

// Interact with content
editor.setDocument('text', 'Hello world');
const content = editor.getDocument('json');

// Listen to events
editor.on('content-changed', (newContent) => {
  console.log('Content updated:', newContent);
});

// Execute commands
editor.dispatchCommand(INSERT_HEADING_COMMAND, { tag: 'h2' });

🔌 Available Plugins

Core Plugins

Plugin Description Features
CommonPlugin Foundation editor components ReactEditor, ReactEditorContent, ReactPlainText, base utilities
MarkdownPlugin Markdown processing engine Shortcuts, transformers, serialization, custom writers
UploadPlugin File upload management system Priority handlers, drag-drop, multi-source uploads

Content Plugins

Plugin Description Features
ReactSlashPlugin Slash command menu system / and @ triggered menus, customizable items, async search
ReactMentionPlugin User mention support @username mentions, custom markdown output, async user search
ReactImagePlugin Image handling Upload, display, drag & drop, captions, resizing
ReactCodeblockPlugin Code syntax highlighting Shiki-powered, 100+ languages, custom themes, color schemes
ReactListPlugin List management Ordered/unordered lists, nested lists, keyboard shortcuts
ReactLinkPlugin Link management Auto-detection, validation, previews, custom styling
ReactTablePlugin Table support Insert tables, edit cells, add/remove rows/columns, i18n
ReactHRPlugin Horizontal rules Divider insertion, custom styling, markdown shortcuts
ReactFilePlugin File attachments File upload, status tracking, validation, drag-drop

Plugin Architecture

All plugins follow a dual-architecture design:

🧠 Kernel Layer (Framework-agnostic)

  • Plugin Interface: Standardized plugin system with lifecycle management
  • Service Container: Centralized service registration and dependency injection
  • Command System: Event-driven command pattern for editor operations
  • Node System: Custom node types with serialization and transformation
  • Data Sources: Content management and format conversion (JSON, Markdown, Text)

⚛️ React Layer (React-specific)

  • React Components: High-level components for easy integration
  • Hook Integration: Custom hooks for editor state and functionality
  • Event Handling: React-friendly event system and callbacks
  • UI Components: Pre-built UI elements with theming support

Plugin Features

  • Fully configurable with TypeScript-typed options
  • Composable - use any combination together
  • Extensible - create custom plugins using the same API
  • Event-driven - react to user interactions and content changes
  • Service-oriented - modular architecture with dependency injection
  • Internationalization - Built-in i18n support where applicable
  • Markdown integration - Shortcuts, import/export, custom transformers
  • Theme system - Customizable styling and appearance
  • Command pattern - Programmatic control and automation

📖 API Reference

Utility Hooks

// Get editor reference
const editorRef = Editor.useEditor();

// Helper for plugin configuration
const PluginWithConfig = Editor.withProps(ReactFilePlugin, {
  handleUpload: async (file) => ({ url: 'uploaded-url' }),
});

Editor Kernel

createEditor(): IEditor

Create a new editor kernel instance:

const editor = createEditor();

IEditor Interface

Core editor methods:

interface IEditor {
  // Content management
  setDocument(type: string, content: any): void;
  getDocument(type: string): any;

  // Plugin system
  registerPlugin<T>(plugin: Constructor<T>, config?: T): IEditor;
  registerPlugins(plugins: Plugin[]): IEditor;

  // Commands
  dispatchCommand<T>(command: LexicalCommand<T>, payload: T): boolean;

  // Events
  on<T>(event: string, listener: (data: T) => void): this;
  off<T>(event: string, listener: (data: T) => void): this;

  // Lifecycle
  focus(): void;
  blur(): void;
  destroy(): void;

  // Access
  getLexicalEditor(): LexicalEditor | null;
  getRootElement(): HTMLElement | null;
  requireService<T>(serviceId: ServiceID<T>): T | null;
}

Plugin System

Creating Custom Plugins

import { IEditorKernel, IEditorPlugin } from '@lobehub/editor';

class MyCustomPlugin implements IEditorPlugin {
  constructor(private config: MyPluginConfig) {}

  initialize(kernel: IEditorKernel) {
    // Register nodes, commands, transforms, etc.
    kernel.registerNode(MyCustomNode);
    kernel.registerCommand(MY_COMMAND, this.handleCommand);
  }

  destroy() {
    // Cleanup
  }
}

Available Commands

Common commands you can dispatch:

// Content insertion
INSERT_HEADING_COMMAND; // { tag: 'h1' | 'h2' | 'h3' }
INSERT_LINK_COMMAND; // { url: string, text?: string }
INSERT_IMAGE_COMMAND; // { src: string, alt?: string }
INSERT_TABLE_COMMAND; // { rows: number, columns: number }
INSERT_MENTION_COMMAND; // { label: string, extra?: any }
INSERT_FILE_COMMAND; // { file: File }
INSERT_HORIZONTAL_RULE_COMMAND;

// Text formatting
FORMAT_TEXT_COMMAND; // { format: 'bold' | 'italic' | 'underline' }
CLEAR_FORMAT_COMMAND;

🛠️ Development

Setup

You can use Github Codespaces for online development:

Or clone it for local development:

$ git clone https://github.com/lobehub/lobe-editor.git
$ cd lobe-editor
$ pnpm install
$ pnpm run dev

This will start the Dumi documentation server with live playground at http://localhost:8000.

Available Scripts

Script Description
pnpm dev Start Dumi development server with playground
pnpm build Build library and generate type definitions
pnpm test Run tests with Vitest
pnpm test:coverage Run tests with coverage report
pnpm lint Lint and fix code with ESLint
pnpm type-check Type check with TypeScript
pnpm ci Run all CI checks (lint, type-check, test)
pnpm docs:build Build documentation for production
pnpm release Publish new version with semantic-release

Project Architecture

lobe-editor/
├── src/
│   ├── editor-kernel/           # 🧠 Core editor logic
│   │   ├── kernel.ts           # Main editor class with plugin system
│   │   ├── data-source.ts      # Content management (JSON/Markdown/Text)
│   │   ├── service.ts          # Service container and dependency injection
│   │   ├── plugin/             # Plugin base classes and interfaces
│   │   ├── react/              # React integration layer
│   │   └── types.ts            # TypeScript interfaces
│   │
│   ├── plugins/                # 🔌 Feature plugins
│   │   ├── common/             # 🏗️ Foundation components
│   │   │   ├── plugin/         # Base editor plugin
│   │   │   ├── react/          # ReactEditor, ReactEditorContent, ReactPlainText
│   │   │   ├── data-source/    # Content data sources
│   │   │   └── utils/          # Common utilities
│   │   │
│   │   ├── markdown/           # 📝 Markdown processing engine
│   │   │   ├── plugin/         # Markdown transformation plugin
│   │   │   ├── service/        # Markdown shortcut service
│   │   │   ├── data-source/    # Markdown serialization
│   │   │   └── utils/          # Transformer utilities
│   │   │
│   │   ├── upload/             # 📤 Upload management system
│   │   │   ├── plugin/         # Upload handling plugin
│   │   │   ├── service/        # Upload service with priority system
│   │   │   └── utils/          # Upload utilities
│   │   │
│   │   ├── slash/              # ⚡ Slash commands (/, @)
│   │   │   ├── plugin/         # Slash detection plugin
│   │   │   ├── react/          # ReactSlashPlugin, ReactSlashOption
│   │   │   ├── service/        # Slash service with fuzzy search
│   │   │   └── utils/          # Search and trigger utilities
│   │   │
│   │   ├── mention/            # 👤 @mention system
│   │   │   ├── plugin/         # Mention plugin with decorators
│   │   │   ├── react/          # ReactMentionPlugin
│   │   │   ├── command/        # INSERT_MENTION_COMMAND
│   │   │   └── node/           # MentionNode with serialization
│   │   │
│   │   ├── codeblock/          # 🎨 Syntax highlighting
│   │   │   ├── plugin/         # Codeblock plugin with Shiki
│   │   │   ├── react/          # ReactCodeblockPlugin
│   │   │   ├── command/        # Language and color commands
│   │   │   └── utils/          # Language detection
│   │   │
│   │   ├── image/              # 🖼️ Image upload & display
│   │   │   ├── plugin/         # Image plugin with captions
│   │   │   ├── react/          # ReactImagePlugin
│   │   │   ├── command/        # INSERT_IMAGE_COMMAND
│   │   │   └── node/           # BaseImageNode, ImageNode
│   │   │
│   │   ├── table/              # 📊 Table support
│   │   │   ├── plugin/         # Table plugin with i18n
│   │   │   ├── react/          # ReactTablePlugin
│   │   │   ├── command/        # Table manipulation commands
│   │   │   ├── node/           # Enhanced TableNode
│   │   │   └── utils/          # Table operations
│   │   │
│   │   ├── file/               # 📎 File attachments
│   │   │   ├── plugin/         # File plugin with status tracking
│   │   │   ├── react/          # ReactFilePlugin
│   │   │   ├── command/        # INSERT_FILE_COMMAND
│   │   │   ├── node/           # FileNode with metadata
│   │   │   └── utils/          # File operations
│   │   │
│   │   ├── link/               # 🔗 Link management
│   │   │   ├── plugin/         # Link plugin with validation
│   │   │   ├── react/          # ReactLinkPlugin
│   │   │   ├── command/        # Link commands
│   │   │   └── utils/          # URL validation and detection
│   │   │
│   │   ├── list/               # 📋 Lists (ordered/unordered)
│   │   │   ├── plugin/         # List plugin with nesting
│   │   │   ├── react/          # ReactListPlugin
│   │   │   ├── command/        # List manipulation commands
│   │   │   └── utils/          # List operations
│   │   │
│   │   └── hr/                 # ➖ Horizontal rules
│   │       ├── plugin/         # HR plugin with styling
│   │       ├── react/          # ReactHRPlugin
│   │       ├── command/        # HR insertion commands
│   │       └── node/           # HorizontalRuleNode
│   │
│   ├── react/                  # ⚛️ High-level React components
│   │   ├── Editor/             # Main Editor component with plugins
│   │   ├── ChatInput/          # Chat interface component
│   │   ├── ChatInputActions/   # Chat action buttons
│   │   ├── ChatInputActionBar/ # Action bar layout
│   │   ├── SendButton/         # Send button with states
│   │   └── CodeLanguageSelect/ # Code language selector
│   │
│   └── index.ts                # Public API exports
│
├── docs/                       # 📚 Documentation source
├── tests/                      # 🧪 Test files
├── vitest.config.ts           # Test configuration
└── .dumi/                      # Dumi doc build cache

The architecture follows a dual-layer design:

  1. Kernel Layer (editor-kernel/) - Framework-agnostic core with plugin system
  2. React Layer (react/ + plugins/*/react/) - React-specific implementations

Each plugin follows a consistent structure:

  • plugin/ - Core plugin logic and node definitions
  • react/ - React components and hooks (if applicable)
  • command/ - Editor commands and handlers
  • service/ - Services and business logic
  • node/ - Custom Lexical nodes
  • utils/ - Utility functions and helpers

This allows for maximum flexibility - you can use just the kernel for custom integrations, or the React components for rapid development.

🤝 Contributing

Contributions of all types are more than welcome, if you are interested in contributing code, feel free to check out our GitHub Issues to get stuck in to show us what you're made of.

🔗 Links

More Products

  • 🤯 Lobe Chat - An open-source, extensible (Function Calling), high-performance chatbot framework. It supports one-click free deployment of your private ChatGPT/LLM web application.
  • 🅰️ Lobe Theme - The modern theme for stable diffusion webui, exquisite interface design, highly customizable UI, and efficiency boosting features.
  • 🧸 Lobe Vidol - Experience the magic of virtual idol creation with Lobe Vidol, enjoy the elegance of our Exquisite UI Design, dance along using MMD Dance Support, and engage in Smooth Conversations.

Design Resources

  • 🍭 Lobe UI - An open-source UI component library for building AIGC web apps.
  • 🥨 Lobe Icons - Popular AI / LLM Model Brand SVG Logo and Icon Collection.
  • 📊 Lobe Charts - React modern charts components built on recharts

Development Resources

  • 🎤 Lobe TTS - A high-quality & reliable TTS/STT library for Server and Browser
  • 🌏 Lobe i18n - Automation ai tool for the i18n (internationalization) translation process.

More Resources


📝 License

Copyright © 2025 LobeHub.
This project is MIT licensed.

About

✒️ Lobe Editor - a modern, extensible rich text editor built on Meta's Lexical framework with dual-architecture design, featuring both a powerful kernel and React integration. Optimized for AI applications and chat interfaces.

Topics

Resources

License

Stars

Watchers

Forks

Sponsor this project

  •  

Contributors 3

  •  
  •  
  •  

Languages