Use React components in Markdown using MDX.
The following components are available out of the box for use in Markdown.
If you'd like to build and add your own custom components, see the Custom Components section below.
Built-in Components
Callout
No Icon
This is a danger callout. It uses the props type='danger'
.
You can embed Markdown inside a callout
.
This is a default callout. It uses the props type='default'
.
You can embed Markdown inside a callout
.
This is an info callout. It uses the props type='info'
.
You can embed Markdown inside a callout
.
This is a success callout. It uses the props type='success'
.
You can embed Markdown inside a callout
.
This is a warning callout. It uses the props type='warning'
.
You can embed Markdown inside a callout
.
With Icon
This is a danger callout. It uses the props type='danger'
.
You can embed Markdown inside a callout
.
This is a default callout. It uses the props type='default'
.
You can embed Markdown inside a callout
.
This is an info callout. It uses the props type='info'
.
You can embed Markdown inside a callout
.
This is a success callout. It uses the props type='success'
.
You can embed Markdown inside a callout
.
This is a warning callout. It uses the props type='warning'
.
You can embed Markdown inside a callout
.
You can also add your own icon but specifying the icon
prop. For example:
In order for this to work, withIcon
must be set to false
.
Card
Heading
You can use markdown inside cards.
View
You can also use HTML to embed cards in a grid.
Card One
You can use markdown inside cards.
ViewCard Two
You can also use inline code
and code blocks.
View
Custom Components
You can add your own custom components using the components
props from useMDXComponent
.
Once you've added your custom component, you can use it in MDX as follows:
HTML Elements
You can overwrite HTML elements using the same technique above.
This will overwrite the <hr />
tag or ---
in Markdown with the HTML output above.
Styling
Tailwind CSS classes can be used inside MDX for styling.
Make sure you have configured the path to your content in your tailwind.config.js
file: