Tiny Markdown to JSON Parser data:image/s3,"s3://crabby-images/d7286/d7286a19c836134b18541a0681762ac392fc1e12" alt=""
data:image/s3,"s3://crabby-images/e31be/e31be3b62d29d9f48a42c602077e901cc7fe4c9b" alt="Gitpod ready-to-code"
Tiny Md Parser is a lightweight, extendable markdown to JSON parser that can be easily customized to support custom markdown elements. It seamlessly integrates with build tools, enabling the creation of markdown components for frameworks like React, Vue, and more. Additionally, it supports CDN links in HTML, allowing for browser-based JavaScript functionality.
We are trying to confirm to commonMark specs. Some of the APIs might change!
At this time, source code may only be available to the sponsors.
Please consider starring this repository and sharing it with your friends.
Getting Started
Installation
pnpm add @tinymd/md2json
or
npm install @tinymd/md2json
or
yarn add @tinymd/md2json
Usage
import { md2json, type Element } from "@tinymd/md2json";
const blocks: Element[] = md2json(markdownString);
Options
export interface Md2JsonOptions {
skipRanks?: number[];
skipTags?: ElementTag[];
blockParsers?: BlockParser[];
inlineParsers?: InlineParser[];
}
Types - Useful for Extending Functionality
export type ElementTag =
| "h1"
| "h2"
| "h3"
| "h4"
| "h5"
| "h6"
| "pre"
| "blockquote"
| "hr"
| "ul"
| "ol"
| "li"
| "p"
| "code"
| "a"
| "img"
| "strong"
| "em"
| "span"
| "small"
| "s"
| "u"
| "br";
export type Attribute = "href" | "src" | "alt" | "class" | "title";
export type Props = Partial<Record<Attribute, string>>;
export interface Element {
tag: ElementTag;
contents: (string | Element)[];
props?: Props;
info?: string;
}
export type References = Record<string, Props>;
export type BlockParserFunction = (
lines: string[],
currentIndex: number,
references?: References,
blockParsers?: BlockParser[],
) => [content: (string | Element)[], linesConsumed: number] | undefined;
export type BlockParser = [
rank: number,
parser: BlockParserFunction,
tag: ElementTag,
];
export type InlineParserFunction = (
blocks: (Element | string)[],
parsers: InlineParser[],
references: Record<string, Props>,
) => void;
export type InlineParser = [
rank: number,
parser: InlineParserFunction,
tag?: ElementTag,
];
License
This library is licensed under the MPL-2.0 open-source license.
Please consider enrolling in our courses or sponsoring our work.
with 💖 by Mayank Kumar Chaudhari