Skip to main content
  • Created:
  • Updated:
  • Author:
    Takeshi Takatsudo

Usage

CLI

# Check files (exit with error if formatting needed)
mdx-formatter --check "**/*.{md,mdx}"

# Format files in place
mdx-formatter --write "**/*.{md,mdx}"

# Preview what would be changed (default)
mdx-formatter "**/*.{md,mdx}"

# Ignore specific patterns
mdx-formatter --write "**/*.md" --ignore "node_modules/**,dist/**"

# Use a custom config file
mdx-formatter --write "**/*.md" --config ./my-config.json

API

import { format } from '@takazudo/mdx-formatter';

// Format a string
const formatted = await format('# Hello\nWorld');
console.log(formatted); // '# Hello\n\nWorld'

// Format with custom settings
const formatted2 = await format(content, {
settings: {
addEmptyLinesInBlockJsx: {
blockComponents: ['Outro', 'InfoBox'],
},
indentJsxContent: {
containerComponents: ['Outro', 'InfoBox'],
},
formatMultiLineJsx: {
ignoreComponents: ['CodeBlock'],
},
},
});

Stdin

cat file.md | ./format-stdin.js > formatted.md

Integration with lint-staged

Add to your package.json:

{
"lint-staged": {
"*.{md,mdx}": ["mdx-formatter --write"]
}
}