This guide demonstrates how to use Plate in React Server Components (RSC) for tasks like static content generation or server-side data processing. Plate's core is designed to be server-safe, allowing you to work with editor content without a browser environment.
Key RSC Constraint
When using Plate in RSC, you must not import from /react subpaths of any platejs* package. Always use the base imports (e.g., @platejs/basic-nodes instead of @platejs/basic-nodes/react).
This means you cannot use createPlateEditor from platejs/react. Instead, use createSlateEditor from platejs.
Install Plate
Install the core Plate package and any specific plugin packages you need.
pnpm add platejs @platejs/basic-nodes
Create an Editor Instance
In an RSC environment, you use createSlateEditor from platejs to initialize an editor instance. This function doesn't rely on React hooks or client-side specific code.
Here's an example demonstrating how to set up an editor with various plugins, similar to the Server-Side Example:
import { createSlateEditor } from 'platejs';
import { AutoformatPlugin } from '@platejs/autoformat';
import { BaseTextAlignPlugin } from '@platejs/basic-styles';
import {
  BaseBoldPlugin,
  BaseCodePlugin,
  BaseItalicPlugin,
  BaseBlockquotePlugin,
  BaseH1Plugin,
  BaseH2Plugin,
  BaseH3Plugin,
} from '@platejs/basic-nodes';
import { MarkdownPlugin, remarkMdx } from '@platejs/markdown';
import remarkGfm from 'remark-gfm';
import remarkMath from 'remark-math';
 
// Example initial value
const initialValue = [
  { type: 'h1', children: [{ text: 'Server-Generated Document' }] },
  { type: 'p', children: [{ text: 'This content was processed on the server.' }] },
  { type: 'blockquote', children: [{ text: 'This is a quote.' }] },
  { type: 'p', children: [{ text: 'And this is bold.', bold: true }] },
];
 
// Create the editor instance
const editor = createSlateEditor({
  plugins: [
    // Block plugins
    BaseH1Plugin,
    BaseH2Plugin,
    BaseH3Plugin,
    BaseBlockquotePlugin,
    BaseTextAlignPlugin,
    // ... add more element plugins as needed
 
    // Mark plugins
    BaseBoldPlugin,
    BaseItalicPlugin,
    BaseCodePlugin,
    // ... add more mark plugins
 
    // Functionality plugins
    AutoformatPlugin,
    MarkdownPlugin.configure({ // For serialization example
      options: {
        remarkPlugins: [remarkMath, remarkGfm, remarkMdx],
      },
    }),
    // ... add other functional plugins
  ],
  value: initialValue, // Set initial content
});
 
// You can now use editor.children, editor.api, editor.tf, etc.
// For example, to get the text content:
const textContent = editor.api.string([]);
// console.debug('Text Content:', textContent);
 
// Or to serialize to Markdown:
const markdown = editor.api.markdown.serialize();
// console.debug('Markdown Output:', markdown);
 
// The editor instance can be used for various server-side tasks.
// For a complete example of using this in an RSC page for rendering,
// see the /docs/examples/server-side page.createSlateEditor creates a raw Plate editor instance. It's suitable for server-side logic, data transformation, or preparing content for static rendering. Check out the full Server-Side Example to see it in action.
Content Manipulation
The primary use case for Plate in RSC is programmatic content manipulation:
- 
editor.api: Access various utility functions for querying the editor state. For example:- editor.api.nodes({ at: [], match }): Find specific nodes.
- editor.api.string([]): Extract text content.
- HTML Serialization
- Markdown Serialization
 
- 
editor.tf: Use transform functions to modify the editor content. For example:- editor.tf.insertNodes(nodes, opts): Insert new nodes.
- editor.tf.removeNodes(opts): Delete nodes.
- editor.tf.setNodes(props, opts): Update properties of existing nodes.
- editor.tf.normalize({ force: true }): Normalize the editor.
 
Next Steps
With Plate configured in your RSC environment, you can now:
- Build server-side content generation and transformation pipelines.
- Perform bulk updates or transformations on your existing Plate documents.
- Validate content structure or extract specific data from your documents.
- Integrate with other backend services for content processing.
- Explore Markdown Serialization, HTML Serialization, and PlateStaticif you need to generate static content.