Configuration
Configuration Options
Section titled “Configuration Options”The astro-mermaid integration accepts the following options:
The default Mermaid theme to use.
- Type:
'default' | 'dark' | 'forest' | 'neutral' | 'base'
- Default:
'default'
mermaid({ theme: 'forest'})
autoTheme
Section titled “autoTheme”Enable automatic theme switching based on the data-theme
attribute on the document root.
- Type:
boolean
- Default:
true
When enabled:
data-theme="light"
→ uses ‘default’ mermaid themedata-theme="dark"
→ uses ‘dark’ mermaid theme
mermaid({ autoTheme: false // Disable auto theme switching})
mermaidConfig
Section titled “mermaidConfig”Additional Mermaid configuration options. See the Mermaid configuration documentation for all available options.
- Type:
object
- Default:
{}
mermaid({ mermaidConfig: { startOnLoad: false, flowchart: { curve: 'basis', padding: 15 }, sequence: { diagramMarginX: 50, diagramMarginY: 10 }, gantt: { fontSize: 12, numberSectionStyles: 4 } }})
Example Configurations
Section titled “Example Configurations”Minimal Setup
Section titled “Minimal Setup”import { defineConfig } from 'astro/config';import mermaid from 'astro-mermaid';
export default defineConfig({ integrations: [mermaid()]});
Dark Theme with Custom Flowchart
Section titled “Dark Theme with Custom Flowchart”import { defineConfig } from 'astro/config';import mermaid from 'astro-mermaid';
export default defineConfig({ integrations: [ mermaid({ theme: 'dark', autoTheme: false, mermaidConfig: { flowchart: { curve: 'linear', nodeSpacing: 50, rankSpacing: 50 } } }) ]});
Production Optimized
Section titled “Production Optimized”import { defineConfig } from 'astro/config';import mermaid from 'astro-mermaid';
export default defineConfig({ integrations: [ mermaid({ theme: 'neutral', autoTheme: true, mermaidConfig: { startOnLoad: false, logLevel: 'error', securityLevel: 'strict' } }) ]});