Writing Remotion Documentation
Documentation lives in
as
files.
Adding a new page
- Create a new file in
- Add the document to
packages/docs/sidebars.ts
- Write the content following guidelines below
- Run in to generate social preview cards
Breadcrumb (): If a documentation page belongs to a package, add
crumb: '@remotion/package-name'
to the frontmatter. This displays the package name as a breadcrumb above the title.
md
---
image: /generated/articles-docs-my-package-my-api.png
title: '<MyComponent>'
crumb: '@remotion/my-package'
---
One API per page: Each function or API should have its own dedicated documentation page. Do not combine multiple APIs (e.g.,
getEncodableVideoCodecs()
and
getEncodableAudioCodecs()
) on a single page.
Public API only: Documentation is for public APIs only. Do not mention, reference, or compare against internal/private APIs or implementation details.
Use headings for all fields: When documenting API options or return values, each property should be its own heading. Use
for top-level properties and
for nested properties within an options object. Do not use bullet points for individual fields.
Language guidelines
- Keep it brief: Developers don't like to read. Extra words cause information loss.
- Link to terminology: Use terminology page for Remotion-specific terms.
- Avoid emotions: Remove filler like "Great! Let's move on..." - it adds no information.
- Separate into paragraphs: Break up long sections.
- Address as "you": Not "we".
- Don't blame the user: Say "The input is invalid" not "You provided wrong input".
- Don't assume it's easy: Avoid "simply" and "just" - beginners may struggle.
Code snippets
Basic syntax highlighting:
Type-safe snippets (preferred)
Use
to check snippets against TypeScript:
md
```ts twoslash
import {useCurrentFrame} from 'remotion';
const frame = useCurrentFrame();
```
Hiding imports
Use
to hide setup code - only content below is displayed:
md
```ts twoslash
import {useCurrentFrame} from 'remotion';
// ---cut---
const frame = useCurrentFrame();
```
Adding titles
Always add a
to code fences that show example usage:
md
```ts twoslash title="MyComponent.tsx"
console.log('Hello');
```
Special components
Steps
md
- <Step>1</Step> First step
- <Step>2</Step> Second step
Experimental badge
md
<ExperimentalBadge>
<p>This feature is experimental.</p>
</ExperimentalBadge>
Interactive demos
Demos must be implemented in
packages/docs/components/demos/index.tsx
. See the
skill for details on adding new demos.
AvailableFrom
Use to indicate when a feature or parameter was added. No import needed - it's globally available.
For page-level version indicators, use an
heading with
inline so it appears next to the title (not below it). Use
and
to escape angle brackets in component names:
md
# <MyComponent><AvailableFrom v="4.0.123" />
md
# @remotion/my-package<AvailableFrom v="4.0.123" />
For section headings:
md
## Saving to another cloud<AvailableFrom v="3.2.23" />
CompatibilityTable
Use to indicate which runtimes and environments a component or API supports. No import needed. Place it in a
section before
.
Available boolean props:
,
,
,
,
,
,
. Set to
(supported) or
(not supported).
Set to empty string
for not applicable if this is a frontend API:
,
,
.
Use
to hide the Node.js/Bun/serverless row if this is a frontend API.
md
## Compatibility
<CompatibilityTable chrome firefox safari nodejs="" bun="" serverlessFunctions="" clientSideRendering={false} serverSideRendering player studio hideServers />
Optional parameters
For optional parameters in API documentation:
- Add to the heading - this indicates the parameter is optional
--> Don't do it if it is a CLI flag (beginning with ) - CLI flags are always optional
- Do NOT add text - the suffix is sufficient
- Include default value in description - mention it naturally in the text
md
### onError?
Called when an error occurs. Default: errors are thrown.
Do NOT do this:
md
### onError?
_optional_
Called when an error occurs.
Combining optional and AvailableFrom
When a parameter is both optional and was added in a specific version:
md
### onError?<AvailableFrom v="4.0.50" />
Called when an error occurs.
"Optional since" pattern
If a parameter became optional in a specific version (was previously required):
md
### codec?
Optional since <AvailableFrom v="5.0.0" inline />. Previously required.
Generating preview cards
After adding or editing a page, generate social media preview cards:
bash
cd packages/docs && bun render-cards.ts
Verifying docs compile
To check that documentation builds without errors:
bash
# from the monorepo root
bun run build-docs
This validates MDX syntax, twoslash snippets, and broken links.