mdx-deck includes a few built-in components to help with creating presentations.
Use the <Head />
component to set content in the document head.
// example for twitter cards
import { Head } from 'mdx-deck'
<Head>
<title>My Presentation</title>
<meta name='twitter:card' content='summary_large_image' />
<meta name='twitter:site' content='@jxnblk' />
<meta name='twitter:title' content='My Presentation' />
<meta name='twitter:description' content='A really great presentation' />
<meta name='twitter:image' content='https://example.com/card.png' />
</Head>
Use the <Image />
component to render a fullscreen image (using the CSS background-image
property).
import { Image } from 'mdx-deck'
<Image src='kitten.png' />
src
(string) image URLsize
(string) CSS background-size
Use the <Appear />
component to make its children appear one at a time within a single slide.
Use the up and down arrow keys to step through each element.
import { Appear } from 'mdx-deck'
<ul>
<Appear>
<li>One</li>
<li>Two</li>
<li>Three</li>
</Appear>
</ul>
Speaker notes that only show in presenter mode can be added to any slide with either markdown syntax or with the Notes component.
# Markdown speaker notes
```notes
These are only visible in presenter mode
```
import { Notes } from 'mdx-deck'
# Slide Content
<Notes>
Only visible in presenter mode
</Notes>
mdx-deck includes a few built-in layouts for common slide variations.
Export a layout as the default
within a slide to wrap the contents.
Inverts the foreground and background colors from the theme.
import { Invert } from 'mdx-deck/layouts'
# Normal
---
export default Invert
# Inverted
Creates a horizontal layout with the first child on the left and all other children on the right.
import { Split } from 'mdx-deck/layouts'
export default Split
![](kitten.png)
## Meow
Same as the Split component, but renders the first child on the right.
import { SplitRight } from 'mdx-deck/layouts'
export default SplitRight
![](kitten.png)
## Meow
Render fenced code blocks fullscreen.
import { FullScreenCode } from 'mdx-deck/layouts'
export default FullScreenCode
```jsx
<Button>Beep</Button>
```