---
name: markdown-editor-integrator
description: This skill should be used when installing and configuring markdown editor functionality using @uiw/react-md-editor. Applies when adding rich text editing, markdown support, WYSIWYG editors, content editing with preview, or text formatting features. Trigger terms include markdown editor, rich text editor, text editor, add markdown, install markdown editor, markdown component, WYSIWYG, content editor, text formatting, editor preview.
---
# Markdown Editor Integrator
Install and configure @uiw/react-md-editor with theme integration, server-side sanitization, controlled/uncontrolled modes, and proper persistence for worldbuilding content.
## When to Use This Skill
Apply this skill when:
- Adding markdown editing capability to forms
- Creating rich text editing for entity descriptions
- Building content management features
- Adding WYSIWYG editing with markdown preview
- Implementing text formatting for character bios, location descriptions, lore entries
- Setting up markdown support for notes and documentation
- Creating editing interfaces for narrative content
## Overview
@uiw/react-md-editor is a React markdown editor with:
- Live preview with split/edit/preview modes
- Syntax highlighting
- Markdown shortcuts and toolbar
- Theme customization
- No SSR issues
- TypeScript support
## Installation Process
### Step 1: Install Dependencies
```bash
npm install @uiw/react-md-editor
```
For sanitization (security):
```bash
npm install rehype-sanitize
```
### Step 2: Configure Next.js (if using)
Add to next.config.js to avoid SSR issues:
```javascript
/** @type {import('next').NextConfig} */
const nextConfig = {
// Other config...
webpack: (config) => {
config.resolve.alias = {
...config.resolve.alias,
'@uiw/react-md-editor': '@uiw/react-md-editor',
}
return config
},
}
module.exports = nextConfig
```
### Step 3: Create Editor Component
Create wrapper component at `components/MarkdownEditor.tsx`:
See assets/MarkdownEditor.tsx for full implementation.
### Step 4: Create Preview Component
Create preview component at `components/MarkdownPreview.tsx`:
See assets/MarkdownPreview.tsx for full implementation.
### Step 5: Integrate Theme Styling
Configure editor to match shadcn/ui theme:
See references/theme-integration.md for detailed theming.
### Step 6: Add Server-Side Sanitization
Implement sanitization for security:
See references/sanitization.md for implementation details.
## Basic Usage Patterns
### Controlled Mode (Recommended for Forms)
```tsx
'use client'
import { useState } from 'react'
import { MarkdownEditor } from '@/components/MarkdownEditor'
import { Button } from '@/components/ui/button'
export function CharacterBioForm() {
const [bio, setBio] = useState('')
async function handleSubmit() {
await saveCharacter({ bio })
}
return (
setBio(value || '')}
height={400}
/>
)
}
```
### With React Hook Form
```tsx
'use client'
import { useForm, Controller } from 'react-hook-form'
import { zodResolver } from '@hookform/resolvers/zod'
import { z } from 'zod'
import { MarkdownEditor } from '@/components/MarkdownEditor'
import {
Form,
FormControl,
FormField,
FormItem,
FormLabel,
FormMessage,
} from '@/components/ui/form'
const schema = z.object({
description: z.string().min(1, 'Description required').max(10000)
})
type FormValues = z.infer
export function LocationForm() {
const form = useForm({
resolver: zodResolver(schema),
defaultValues: {
description: ''
}
})
function onSubmit(values: FormValues) {
console.log(values)
}
return (
)
}
```
### Preview Mode (Display Only)
```tsx
import { MarkdownPreview } from '@/components/MarkdownPreview'
export function CharacterProfile({ character }) {
return (
{character.name}
)
}
```
### Uncontrolled Mode
```tsx
'use client'
import { useRef } from 'react'
import MDEditor from '@uiw/react-md-editor'
export function QuickNoteEditor() {
const editorRef = useRef(null)
function handleSave() {
// Access value from ref if needed
}
return (
)
}
```
## Configuration Options
### Height Control
```tsx
// Fixed height
// Dynamic height
// Auto height
```
### Hide Toolbar
```tsx
```
### Preview Mode
```tsx
```
### Disable Preview
```tsx
```
### Custom Commands
```tsx
import { commands } from '@uiw/react-md-editor'
```
### Extra Commands
```tsx
```
## Theme Integration
### Match shadcn/ui Theme
```tsx
'use client'
import { useTheme } from 'next-themes'
import MDEditor from '@uiw/react-md-editor'
export function ThemedMarkdownEditor({ value, onChange }) {
const { theme } = useTheme()
return (