micromark extensions to support Obsidian Flavored Markdown (OFM) callouts.
This package contains two extensions to add support for OFM callout syntax to micromark
.
As there is no formal specification, this extensions follows the behavior explained in the Obsidian help.
This project is useful if you want to support OFM callouts in your markdown.
You can use these extensions when you are working with micromark
.
To support all OFM features use micromark-extension-ofm
.
All theses packages are used in remark-ofm
which focusses on making it easier to transform content by abstracting these internals away.
This package is ESM only. In Node.js (version 18+), install with npm
:
npm install @moritzrs/micromark-extension-ofm-callout
import { micromark } from "micromark";
import { ofmCallout, ofmCalloutHtml } from "@moritzrs/micromark-extension-ofm-callout";
const output = micromark("> [!type]+ Title\n> Content", {
extensions: [ofmCallout()],
htmlExtensions: [ofmCalloutHtml()],
});
console.log(output);
Yields:
<blockquote class="callout" data-type="type">
<details open="">
<summary>Title</summary>
<p>Content</p>
</details>
</blockquote>
This package exports the identifiers ofmCallout
and ofmCalloutHtml
.
There is no default export.
Creates an extension for micromark
to enable OFM callout syntax.
none
Extension for micromark
that can be passed in extensions
, to enable OFM callout syntax (Extension
).
Creates an extension for micromark
to support OFM callouts when serializing to HTML.
none
Extension for micromark
that can be passed in htmlExtensions
, to support OFM callouts when serializing to HTML (HtmlExtension
).
When authoring markdown with callouts, keep in mind that callouts don't work in most places. If not supported they will be treated as blockquotes and their prefix will be treated as raw text.
When using callouts, the will be expressed as following
<blockquote class="callout" data-type="type">
<details open="">
<summary>Title</summary>
<p>Content</p>
</details>
</blockquote>
callouts can be styled using the following selector.
blockquote.callout {
/** General Callout styling */
}
blockquote.callout[data-type="type"] {
/** Specific Callout type styling */
}
blockquote.callout details {
/** Content */
}
blockquote.callout details summary {
/** Title */
}
Callouts derive from blockquotes and have a prefix that defines its appearance.
Callouts form with the following BNF:
<callout> ::= <prefix> ("\n" <content>)*
<prefix> ::= <space>? ">" <space>? "[" "!" <type> "]" <foldable>? <space> <title>?
<content> ::= <space>? ">" <letter>*
<type> ::= <letter>+ | <type> <space>+
<foldable> ::= "+" | "-"
<title> ::= (<letter> | <space>)+
<letter> ::= [a-z] | [A-Z] | [0-9]
<space> ::= " "
The above grammar is just a rough description and misses out some allowed characters and spaces.
This package was tested to work with micromark
version 4
and later with node version 18
and later.
This package is safe.
-
micromark-extension-ofm
- support for all of OFM -
mdast-util-ofm-callout
- support for OFM callouts in mdast -
mdast-util-ofm
- support for all of OFM in mdast -
remark-ofm
- support for all of OFM in remark
I don't know if i can check PRs in a timely manner, but feel free to open PRs or issues. If participation is high I will need to add a code of conduct and contribution guidelines.
This package is not affiliated with Obsidian.md or the developers of Obsidian.md.
MIT © Moritz R. Schulz