@kayvan/markdown-tree-parser
Version:
A powerful JavaScript library and CLI tool for parsing and manipulating markdown files as tree structures using the remark/unified ecosystem
78 lines (67 loc) • 2.46 kB
JavaScript
/**
* markdown-tree-parser
*
* A powerful JavaScript library for parsing and manipulating markdown files as tree structures.
* Built on top of the remark/unified ecosystem.
*
* @author Kayvan Sylvan <kayvan@sylvan.com>
* @version 1.0.0
* @license MIT
*/
import { MarkdownTreeParser } from './lib/markdown-parser.js';
// Export the main class
export { MarkdownTreeParser };
// Default export for convenience
export default MarkdownTreeParser;
// Export additional utilities that might be useful
export { unified } from 'unified';
export { find } from 'unist-util-find';
export { select, selectAll } from 'unist-util-select';
export { visit } from 'unist-util-visit';
/**
* Convenience function to create a new parser instance
* @param {Object} options - Configuration options for the parser
* @returns {MarkdownTreeParser} New parser instance
*/
export function createParser(options = {}) {
return new MarkdownTreeParser(options);
}
/**
* Quick utility to parse markdown and extract a section
* @param {string} markdown - Markdown content
* @param {string} sectionName - Section heading to extract
* @param {Object} options - Parser options
* @returns {Promise<string|null>} Extracted section as markdown or null
*/
export async function extractSection(markdown, sectionName, options = {}) {
const parser = new MarkdownTreeParser(options);
const tree = await parser.parse(markdown);
const section = parser.extractSection(tree, sectionName);
if (!section) {
return null;
}
return await parser.stringify(section);
}
/**
* Quick utility to get all headings from markdown
* @param {string} markdown - Markdown content
* @param {Object} options - Parser options
* @returns {Promise<Array>} Array of heading objects
*/
export async function getHeadings(markdown, options = {}) {
const parser = new MarkdownTreeParser(options);
const tree = await parser.parse(markdown);
return parser.getHeadingsList(tree);
}
/**
* Quick utility to generate table of contents
* @param {string} markdown - Markdown content
* @param {number} maxLevel - Maximum heading level (default: 3)
* @param {Object} options - Parser options
* @returns {Promise<string>} Table of contents as markdown
*/
export async function generateTOC(markdown, maxLevel = 3, options = {}) {
const parser = new MarkdownTreeParser(options);
const tree = await parser.parse(markdown);
return parser.generateTableOfContents(tree, maxLevel);
}