@gotfeedback/markdown-it-media
v1.0.1
Published
Markdown it plugin with rich media support, including video and audio.
Downloads
90
Maintainers
Readme
Plugin provides a special handling of video and audio and outputs them as
<video>
and <audio>
html elements respectively. Additional attributes are
also provided:
- Media size:
=WxH
(see @mdit/img-size). - Multiple sources:
data:image/s3,"s3://crabby-images/11279/112791eeae33eab8dde0852096b34fbd29feb66d" alt="media/type"
. - Thumbnails:
#=/path/to/poster.jpeg
. - Captions:
[lang](/path/to/captions.lang.vtt)
.
This plugin uses the normal image syntax for all media types, and looks at the
extensions of the URL to determine whether to output <img>
, <audio>
, or
<video>
elements. This is similar to
markdown-it-html5-media. If the extension is missing
or unknown, we default to <img>
.
Installation
npm install @gotfeedback/markdown-it-media
Usage
import markdownIt from "markdown-it";
import markdownItMedia from "@gotfeedback/markdown-it-media";
// optional (with defaults)
const options = {
controls: false,
attrs: {
image: {},
audio: {},
video: {},
},
};
const md = markdownIt().use(markdownItMedia, options);
md.render("data:image/s3,"s3://crabby-images/69225/69225554aa31f63cf9fef548f517b1dca5a247e3" alt="Small Image"");
<p>
<img src="image.jpeg" alt="Small Image" width="85" height="50" />
</p>
md.render("data:image/s3,"s3://crabby-images/3364d/3364d1b93d9ee2346a29019ee2c865c1d7d57a0f" alt="Funny Clip"");
<p>
<video>
<source src="my-video.mp4" />
Funny Clip <a href="my-video.mp4">Download video</a>.
</video>
</p>
Options
Controls
Enable controls with controls
(default false
).
const md = markdownIt().use(markdownItMedia, { controls: true });
md.render("data:image/s3,"s3://crabby-images/a93d8/a93d8b3ceb5761e29ef0b7ba871c46854ab1c2f5" alt=""");
<p>
<video controls>
<source src="my-video.webm" />
<a href="my-video.webm">Download video</a>.
</video>
</p>
Attrs
You can add arbitrary attributes to image, audio, or video using the attrs
option:
const md = markdownIt().use(markdownItMedia, {
attrs: {
image: { lazy: "true" },
video: { crossorigin: "anonymous", autoplay: "autoplay", muted: "muted" },
audio: { crossorigin: "anonymous", preload: "metadata", controls: "true" },
},
});
md.render(`
data:image/s3,"s3://crabby-images/c6c16/c6c168c997a3af87a814174a67feb0a42e1d0ce9" alt=""
data:image/s3,"s3://crabby-images/44fa9/44fa9b57dc48a0ffe746daf9f7aec2aa4410ee20" alt=""
data:image/s3,"s3://crabby-images/c3266/c326693fa07f1a475ff6590e038e335f03df5696" alt="")
`);
<p>
<img src="image.webp" lazy="true" />
<video crossorigin="anonymous" autoplay="autoplay" muted="muted">
<source src="video.webm" />
<a href="video.webm">Download video</a>.
</video>
<audio crossorigin="anonymous" preload="metadata" controls="true">
<source src="audio.webm" type="audio/webm" />
<a href="audio.webm">Download audio</a>.
</audio>
</p>
Media Size
Use the =WxH
syntax to specify the width and height of the image, audio, or
video. Either the width or height can be omitted, but not the literal x
between them. In other words, you can specify only 800 px width with =800x
or
only 600 px height with =x600
.
The size attribute must come after the optional title.
data:image/s3,"s3://crabby-images/f75b0/f75b035a2ecc8512f37ed59db9af04c2a4e46972" alt=""
<img src="image.jpeg" title="Title" width="800" height="600" />
data:image/s3,"s3://crabby-images/be61f/be61fcc10bea83917c97b01ee0c25d3e290e567d" alt=""
<img src="image.jpeg" width="800" />
data:image/s3,"s3://crabby-images/51f52/51f5201114551d26e02891b17b71c65f2c301031" alt=""
<img src="image.jpeg" height="600" />
Multiple Sources / Explicit Media Type
For audio or video You can replace the source or add additional sources using
the data:image/s3,"s3://crabby-images/39a42/39a42d591815b25b3d76cf8a050804de5e1c8025" alt="media/type"
syntax in place or after the source.
Additional sources must come before the optional title.
data:image/s3,"s3://crabby-images/95501/95501fa2cc79976ee089bd192ca0f6563fcdc538" alt="Description" "optional title")
data:image/s3,"s3://crabby-images/08a0f/08a0f333834d6eb721a1e43eb0de74111ec89a8f" alt="Description" data:image/s3,"s3://crabby-images/31e6e/31e6eb0efb60475777ec947f259f8a86fa7a25b5" alt="video/mpeg" "optional title")
The using explicit media source can be handy if you are referencing a video or audio wich doesn’t have a matching file extension.
data:image/s3,"s3://crabby-images/7d3d1/7d3d1554bfcbeb536622a2dbd7eea7636761bb05" alt="Description"> "optional title")
data:image/s3,"s3://crabby-images/05ff4/05ff4d25bfdee93673b9936c3d60cde31599a3f3" alt="webm audio file"%3E> "optional title")
Note: Additional sources or explicit media types are ignored for images.
Thumbnails
Thumbnails (or poster) can be added to a video or audio using the
#=/path/to/poster.jpeg
syntax.
The thumbnail attribute must come after the optional title.
data:image/s3,"s3://crabby-images/97b0a/97b0acba8ffe5b06d0a5713247992c3965f41a52" alt=""
<video poster="thumbnail.jpeg">
<source src="image.jpeg" />
</video>
Note: If you add a thumbnail to an audio, it will result in a <video>
element.
data:image/s3,"s3://crabby-images/7e064/7e0640562a7ee5456d8ec702404315b4cfbd2f31" alt="An audio with thumbnail"
<video poster="album-cover.jpeg">
<source src="song.mp3" />
<!-- ... -->
</video>
Captions
Captions can be added to audio or video using the data:image/s3,"s3://crabby-images/355b8/355b827e17673b6795be99dbff22620995a5508b" alt="lang"
. [lang]
is a language
tag e.g. [zh]
for Chinese,
[en-US]
for US English, or [es-005]
for Latin American Spanish. The source
URL must be a .vtt
file.
You can add multiple captions and the caption attribute must come after the optional title:
data:image/s3,"s3://crabby-images/92fdf/92fdf2ee0777207f4f84e07e9899afa1db37d1cc" alt="" data:image/s3,"s3://crabby-images/d20c0/d20c05a3fde0aad5d1ecff6389033a4042c77d1f" alt="en")
<video title="Title">
<source src="video.webm" />
<track src="chinese-captions.vtt" srclang="zh" kind="captions" />
<track src="english-captions.vtt" srclang="en" kind="captions" />
<!-- ... -->
</video>
Captions can also be labelled:
data:image/s3,"s3://crabby-images/64f5f/64f5f680049748f0661bab677950db48dbb3a1bc" alt="")
<video title="Title">
<source src="video.webm" />
<track
src="captions.vtt"
srclang="en"
label="Caption Label"
kind="captions"
/>
<!-- ... -->
</video>
Note: If you add captions to an audio, it will result in a <video>
element.
data:image/s3,"s3://crabby-images/37fa0/37fa003561762c2192f18f53f8f8a8414aba80d4" alt="An audio with captions")
<video>
<source src="song.mp3" />
<track src="lyrics.vtt" srclang="en" label="Show Lyrics" />
<!-- ... -->
</video>
Examples
An Image with a width of 200 px and auto height:
data:image/s3,"s3://crabby-images/93f3d/93f3d164e4bb7673cad498296185f9238eb514c5" alt="Image description"
<img alt="Image description" title="some title" width="200" />
An audio:
data:image/s3,"s3://crabby-images/29f7b/29f7b680db9d956571c1c33d6449efe8b2b83da2" alt="Audio description"
<audio>
<source src="/path/to/audio.mp3" />
Audio description
<a href="/path/to/audio.mp3">Download audio</a>.
</audio>
A video with a width of 800 px and height of 600 px:
data:image/s3,"s3://crabby-images/66b90/66b90218ad2eb59c58a625d854b6289e2c29a586" alt="Video description"
<video width="800" height="600">
<source src="/path/to/video.webm" />
Video description
<a href="/path/to/video">Download audio</a>.
</video>
A webm video with an alternative mp4 source:
data:image/s3,"s3://crabby-images/955fe/955feb60b22fe4de26c42591ab212dac4923653b" alt="video description" data:image/s3,"s3://crabby-images/8dc47/8dc47af44acf7454f02ab142cf61e08bac8bb21b" alt="video/mpeg")
<video>
<source src="/movie.webm" type="video/webm" />
<source src="/movie.mp4" type="video/mpeg" />
video
<a href="/movie.webm">Download webm video</a>
<a href="/movie.mp4">Download mpeg video</a>.
</video>
Video with a poster:
data:image/s3,"s3://crabby-images/f50d7/f50d763ab1de642e1563ca84df514632bd666929" alt="Video description"
<video poster="/path/to/poster.jpeg">
<source src="/path/to/video.webm" />
Video description
</video>
Video with english and arabic subtitles:
data:image/s3,"s3://crabby-images/d3309/d3309aabc35ba3cdbb68698d72e4c956dbbac089" alt="Video description" [ar](/path/to/captions.ar.vtt))
<video>
<source src="/path/to/video.webm" />
<track kind="captions" src="/path/to/captions.en.vtt" srclang="en" />
<track kind="captions" src="/path/to/captions.ar.vtt" srclang="ar" />
Video description
</video>
Video with thumbnail, a poster, and a webm backup source
data:image/s3,"s3://crabby-images/4f501/4f501954ea9bdc0f63da0a384d6ab211dc7b7e6b" alt="Video with thumbnail, a poster, subtitles, and a webm backup source"
"optional title"
=800x600
#=thumbnail.jpeg
[en](captions.en.vtt "English")
[ar](captions.ar.vtt "Arabic")
)
<video title="optional title" width="800" height="600" poster="thumbnail.jpeg">
<source src="my-video.mp4" />
<source src="my-video.webm" type="video/webm" />
<track src="captions.en.vtt" srclang="en" label="English" kind="captions" />
<track src="captions.ar.vtt" srclang="ar" label="Arabic" kind="captions" />
Video with thumbnail, a poster, subtitles, and a webm backup source
<a href="my-video.mp4">Download video</a>
<a href="my-video.webm">Download webm video</a>.
</video>
Greatly inspired by markdown-it-html5-media and @mdit/img-size