Next.js Example
Craft your next amazing library using
Harness the full potential of React 18 Server Components!
MDAST (Markdown Abstract Syntax Tree) to DOCX
ShowHide Code
--- title: "Markdown Syntax Showcase" description: "A comprehensive example of Markdown syntax supported by mdast." author: "Mayank Chaudhari" date: "2025-03-03" categories: [Markdown, Syntax, Documentation] tags: [mdast, markdown, reference] --- # Markdown Syntax Showcase ## Table of Contents - [Basic Elements](#1-basic-elements) - [Headings](#headings) - [Text Formatting](#text-formatting) - [Blockquote](#blockquote) - [Horizontal Rule](#horizontal-rule) - [Lists](#2-lists) - [Unordered List](#unordered-list) - [Ordered List](#ordered-list) - [Code Blocks](#3-code-blocks) - [Tables](#4-tables) - [Links and Images](#5-links-and-images) - [Task Lists](#6-task-lists-gfm) - [Footnotes](#7-footnotes) - [Emoji](#8-emoji-gfm) - [Math Equations](#9-math-equations-katex--latex) - [Diagrams](#10-diagrams-mermaid) - [Definition Lists](#11-definition-lists) - [Admonitions](#12-admonitions-callouts) - [HTML Elements](#13-html-elements) - [Custom Directives](#14-custom-directives-mdx) ## 1. Basic Elements ### Headings Different levels of headings for structuring content. # Heading 1 The largest heading, usually reserved for the main title of the document. By default, single `#` in markdown is converted to Title. Thus, 'Heading 2', which in markdown is `## Heading 2` will have Heading 1 style applied, unless you set `useTitle` to false in the `sectionProps`. ## Heading 2 A subheading, used to separate major sections. ### Heading 3 A smaller heading, often used for subsections. #### Heading 4 A more detailed subsection heading. ##### Heading 5 A minor heading, used for further breakdown. ###### Heading 6 The smallest heading, typically used for fine details. > #### Nested Blockquote Example > > > ##### Nested Blockquote Level 2 > > > > - List inside a blockquote: > > - **Bold Text** inside a list > > - `Inline Code` inside a list > > > > ```javascript > > console.log("Code inside a blockquote list"); > > ``` ### Text Formatting - **Bold text `with code`** - _Italic text_ - ~~Strikethrough~~ - `Inline code` ### Blockquote > This is a **nested blockquote** example. > > > Another level of nesting. > > > > - List item 1 > > - List item 2 > > - Subitem inside blockquote > > > > ```python > > def nested_function(): > > return "Code inside nested blockquote" > > ``` ### Horizontal Rule --- ## 2. Lists ### Unordered List - Item 1 - Item 2 - Subitem 1 - Subitem 2 - Item 3 ### Ordered List 1. First item 2. Second item 1. Subitem 1 2. Subitem 2 3. Third item ## 3. Code Blocks ### JavaScript Example ```javascript function greet(name) { console.log(`Hello, ${name}!`); } greet("Mayank"); ``` ### Python Example ```python def greet(name): print(f"Hello, {name}!") greet("Mayank") ``` ## 4. Tables Structuring data in tabular format. | Name | Age | Location | | ----- | --- | ------------- | | John | 25 | New York | | Alice | 30 | San Francisco | | Bob | 28 | London | ### Table with md alignments | Left-aligned | Center-aligned | Right-aligned | | :----------- | :------------: | ------------: | | Text 1 | Text 2 | Text 3 | ## 5. Links and Images Adding hyperlinks and images. ### External Links [OpenAI](https://openai.com) ### Internal Links [Back to Table of Contents](#table-of-contents) ### Images Embedding images in Markdown. SVG:  PNG:  Data URL:  ### Reference Links in Markdown This is an example of using reference-style links in Markdown. You can define a reference link like this\ [OpenAI][openai] is an AI research and deployment company. Markdown syntax is explained in detail on [Markdown Guide][md-guide]. #### References [openai]: https://openai.com "OpenAI Website" [md-guide]: https://www.markdownguide.org "Markdown Guide" ## 6. Task Lists (GFM) Checkable task lists. - [x] Task 1 - Completed - [ ] Task 2 - Pending - [ ] Task 3 - Pending - [x] Subtask 3.1 - Done - [ ] Subtask 3.2 - Pending - [ ] Task 4 - In Progress - [ ] Task 5 - Pending Review - [x] Task 6 - Approved Task lists are useful for tracking progress in projects. ## 7. Footnotes Referencing additional information. Here is a statement with a footnote.[^1] [^1]: This is the footnote content. ## 8. Emoji (GFM) Using emojis in Markdown. :smile: :rocket: :tada: :fire: :computer: ## 9. Math Equations (KaTeX / LaTeX) Displaying mathematical expressions. Inline equation: $E=mc^2$ Block equation: $$ \sum_{n=1}^{\infty} \frac{1}{n^2} = \frac{\pi^2}{6} $$ ### Inline Math Inline math expressions can be enclosed within single dollar signs: $E=mc^2$. You can also use `\\(` and `\\)`: $\sum_{i=1}^{n} i^2$. With hat "$$\hat{x}$$". ### Display Math Display math expressions are enclosed within double dollar signs, which renders them on their own line: $$ \int_0^\infty x^2 e^{-x^2} dx = \frac{\sqrt{\pi}}{4} $$ You can also use `\\[` and `\\]`: $$ \frac{d}{dx} \left( \frac{1}{x} \right) = -\frac{1}{x^2} $$ ### Common Math Symbols Here are some common mathematical symbols: - Greek letters: $\alpha$, $\beta$, $\gamma$, $\Gamma$, $\Delta$, $\pi$, $\Pi$, $\Sigma$, $\omega$, $\Omega$ - Superscripts and subscripts: $x^2$, $y_i$, $a^{b+c}$, $e^{-i\omega t}$ - Fractions: $\frac{1}{2}$, $\frac{x+y}{z}$ - Square roots: $\sqrt{x}$, $\sqrt[3]{y}$ - Summations and products: $\sum_{i=1}^n i$, $\prod_{j=1}^m j$ - Integrals: $\int_a^b f(x) dx$, $\oint_C \vec{F} \cdot d\vec{r}$ - Limits: $\lim_{x \to \infty} \frac{1}{x}$ - Vectors: $\vec{v}$, $\mathbf{v}$ - Matrices: $\begin{pmatrix} a & b \\ c & d \end{pmatrix}$ - Partial derivatives: $\frac{\partial f}{\partial x}$ - Infinity: $\infty$ - Logical symbols: $\forall$, $\exists$, $\in$, $\notin$, $\subseteq$, $\supseteq$, $\land$, $\lor$, $\neg$ - Trigonometric functions: $\sin(x)$, $\cos(y)$, $\tan(z)$ - Exponential and logarithmic functions: $e^x$, $\ln(y)$, $\log_{10}(z)$ ### Matrices Matrices can be created using the `pmatrix`, `bmatrix`, `vmatrix`, and `Vmatrix` environments: $$ \begin{pmatrix} 1 & 2 & 3 \\ 4 & 5 & 6 \\ 7 & 8 & 9 \end{pmatrix} $$ $$ \begin{bmatrix} 1 & 2 \\ 3 & 4 \end{bmatrix} $$ $$ \begin{vmatrix} a & b \\ c & d \end{vmatrix} $$ $$ \begin{Vmatrix} a & b \\ c & d \end{Vmatrix} $$ ### Alignments You can align equations using the `align` environment: $$ \begin{align} y &= mx + b \\ y' &= m \end{align} $$ You can also use `aligned` for aligning parts of an equation: $$ f(x) = \begin{cases} x^2, & \text{if } x \ge 0 \\ -x^2, & \text{otherwise} \end{cases} $$ $$ \begin{aligned} (a+b)^2 &= (a+b)(a+b) \\ &= a^2 + ab + ba + b^2 \\ &= a^2 + 2ab + b^2 \end{aligned} $$ ### Case Statements Case statements can be created using the `cases` environment: $$ f(x) = \begin{cases} 1, & \text{if } x > 0 \\ 0, & \text{if } x = 0 \\ -1, & \text{if } x < 0 \end{cases} $$ ### Text in Math You can include text within math expressions using the `\text{}` command: $$ \text{Let } x \text{ be a real number.} $$ ### Colored Math You can color math expressions using the `\textcolor{color}{math}` command: $$ \textcolor{red}{E=mc^2} $$ $$ \textcolor{blue}{\sum_{i=1}^n i} $$ ### Math Macros You can define custom macros: ```latex \newcommand{\norm}[1]{\left\lVert#1\right\rVert} ``` ## 10. Diagrams (Mermaid) Visualizing data with diagrams. ### Flowchart ```mermaid graph TD; A-->B; A-->C; B-->D; C-->D; ``` ### Sequence Diagram ```mermaid sequenceDiagram participant A participant B A->>B: Hello, how are you? B->>A: I'm good, thanks! ``` ### Mindmap ```mindmap - Root - Branch 1 - Subbranch 1 - Subbranch 2 - Branch 2 - Subbranch 3 - Subbranch 4 ``` ### Chart (Gantt) ```mermaid gantt title Project Timeline dateFormat YYYY-MM-DD section Development Task 1 :done, 2024-01-01, 2024-01-10 Task 2 :active, 2024-01-11, 2024-01-20 Task 3 : 2024-01-21, 2024-01-30 ``` ## 11. Definition Lists Defining terms and meanings. Term 1 : Definition 1 Term 2 : Definition 2a : Definition 2b ## 12. Admonitions (Callouts) Highlighting important notes or warnings. > **Note:** This is an important note. > > **Warning:** Be careful with this step! ## 13. HTML Elements Using HTML for additional interactivity. <details> <summary>Click to expand</summary> This is hidden content. </details> This is a checkbox - <input type="checkbox" /> ### 13.1. Inline HTML This is an example of <em>inline HTML</em> inside a paragraph: This is a <span style="color: red; font-weight: bold;">red bold text</span> inside a Markdown paragraph. You can also add **inline images**: <img src="" alt="Sample Image" width="150" height="150" style="border-radius: 10px;" /> Or create **inline links** with styles: <a href="https://openai.com" target="_blank" style="color: blue; text-decoration: none; font-weight: bold;">Visit OpenAI</a> <h3>13.2. Block HTML Elements</h3> <pre> Inside pre tag Indentation and formatting etc. here should be preserved. Hmmm... </pre> #### Tables with HTML <table border="1" cellspacing="0" cellpadding="10"> <tr> <th>Name</th> <th>Age</th> <th>Location</th> </tr> <tr> <td>John</td> <td align="center">25</td> <td>New York</td> </tr> <tr> <td>Alice</td> <td>30</td> <td>San Francisco</td> </tr> </table> #### Forms in HTML <form action="#" method="post"> <p> <label for="name">Name:</label> <input type="text" id="name" name="name" /> </p> <p> <label for="email">Email:</label> <input type="email" id="email" name="email" /> </p> <input type="submit" value="Submit" /> </form> ### 13.3. Combining Markdown and HTML > This is a **blockquote** with an embedded **HTML table**: > > <table border="1"> > <tr> > <th>Feature</th> > <th>Supported</th> > </tr> > <tr> > <td>Markdown</td> > <td>✅</td> > </tr> > <tr> > <td>HTML</td> > <td>✅</td> > </tr> > </table> ### 13.4. Custom Styling <style> table { border-collapse: collapse; width: 100%; } th, td { border: 1px solid black; padding: 8px; text-align: left; } th { background-color: #f2f2f2; } </style> ## 14. Custom Directives (MDX) Embedding custom components. ```mdx <MyComponent title="Hello World" /> ``` --- This document covers most of the syntax supported by `mdast`, including extended Markdown features such as GFM, math, diagrams, and MDX components.
ShowHide Code
import { readFileSync } from "fs"; import { unified } from "unified"; import remarkParse from "remark-parse"; import remarkGfm from "remark-gfm"; import remarkFrontmatter from "remark-frontmatter"; import remarkMath from "remark-math"; import { toDocx } from "mdast2docx"; import { tablePlugin, listPlugin, mathPlugin } from "mdast2docx/dist/plugins"; import { NextResponse } from "next/server"; const docxProcessor = unified() .use(remarkParse) .use(remarkGfm) .use(remarkFrontmatter) .use(remarkMath); /** * Generate a docx file from markdown on server side. * @returns docx file */ export const GET = async () => { const md = readFileSync("../../sample.md", "utf-8"); const mdast = docxProcessor.parse(md); const buffer = await toDocx( mdast, {}, { plugins: [tablePlugin(), listPlugin(), mathPlugin()] }, "arraybuffer", ); return new NextResponse(new Uint8Array(buffer as ArrayBuffer), { status: 200, headers: { "Content-Type": "application/vnd.openxmlformats-officedocument.wordprocessingml.document", "Content-Disposition": 'attachment; filename="sample.docx"', }, }); };