@object-ui/plugin-markdown
v3.0.2
Published
Markdown rendering plugin for Object UI, powered by react-markdown
Readme
Plugin Markdown - Lazy-Loaded Markdown Renderer
A lazy-loaded markdown component for Object UI based on react-markdown with GitHub Flavored Markdown support.
Features
- Internal Lazy Loading: react-markdown is loaded on-demand using
React.lazy()andSuspense - Zero Configuration: Just import the package and use
type: 'markdown'in your schema - Automatic Registration: Components auto-register with the ComponentRegistry
- Skeleton Loading: Shows a skeleton while react-markdown loads
- XSS Protection: All content is sanitized via rehype-sanitize
- GitHub Flavored Markdown: Full support for tables, strikethrough, task lists, etc.
Installation
pnpm add @object-ui/plugin-markdownUsage
Automatic Registration (Side-Effect Import)
// In your app entry point (e.g., App.tsx or main.tsx)
import '@object-ui/plugin-markdown';
// Now you can use markdown type in your schemas
const schema = {
type: 'markdown',
content: '# Hello World\n\nThis is **markdown** text.'
};Manual Integration
import { markdownComponents } from '@object-ui/plugin-markdown';
import { ComponentRegistry } from '@object-ui/core';
// Manually register if needed
Object.entries(markdownComponents).forEach(([type, component]) => {
ComponentRegistry.register(type, component);
});TypeScript Support
The plugin exports TypeScript types for full type safety:
import type { MarkdownSchema } from '@object-ui/plugin-markdown';
const schema: MarkdownSchema = {
type: 'markdown',
content: '# Hello World\n\nThis is **markdown** text.'
};Schema API
{
type: 'markdown',
content?: string, // Markdown content (supports GitHub Flavored Markdown)
className?: string // Tailwind classes
}Supported Markdown Features
- Headers (H1-H6)
- Bold, italic, and inline code
- Links and images
- Lists (ordered, unordered, and nested)
- Tables
- Blockquotes
- Code blocks with syntax highlighting
- Strikethrough
- Task lists
- Autolinks
Lazy Loading Architecture
The plugin uses a two-file pattern for optimal code splitting:
MarkdownImpl.tsx: Contains the actual react-markdown import (heavy ~100-200 KB)index.tsx: Entry point withReact.lazy()wrapper (light)
When bundled, Vite automatically creates separate chunks:
index.js(~200 bytes) - The entry pointMarkdownImpl-xxx.js(~100-200 KB) - The lazy-loaded implementation
The react-markdown library is only downloaded when a markdown component is actually rendered, not on initial page load.
Bundle Size Impact
By using lazy loading, the main application bundle stays lean:
- Without lazy loading: +100-200 KB on initial load
- With lazy loading: +0.19 KB on initial load, +100-200 KB only when markdown is rendered
This results in significantly faster initial page loads for applications that don't use markdown on every page.
Development
# Build the plugin
pnpm build
# The package will generate proper ESM and UMD builds with lazy loading preserved