name: write-docs description: Authoring Fern MDX documentation pages for the Opik docs site, plus release-note and changelog routing. Use when writing or updating pages under apps/opik-documentation/documentation/fern/, drafting PR descriptions, or picking the right changelog surface.
Write Docs
The Opik docs site is built with Fern from MDX sources under apps/opik-documentation/documentation/fern/. Two content surfaces coexist:
fern/docs/— v1 (the established surface, source of style truth)fern/docs-v2/— latest (where new pages go)
New pages should land in docs-v2/. v1 is the reference for writing style and component usage because it is far richer.
Where new pages live
- Create the file at
apps/opik-documentation/documentation/fern/docs-v2/<section>/<page-name>.mdx. - Register it in
fern/versions/latest.ymlunder the rightsection:block. - Only touch
fern/versions/v1.ymlif the page must also ship in the v1 build (rare). - Do not edit
fern/docs.ymlwhen adding a page — that file is the global site config (tabs, redirects), not per-version routing. - Routing is not implied by folder layout. Always check the version YAML.
Frontmatter template
Every page uses YAML frontmatter. title and headline are required; the og:* fields are strongly recommended for SEO/social sharing and are present on every page. Do not repeat title as an inline # H1 in the body — Fern renders it from frontmatter.
---
title: Page Title
headline: Page Title | Opik Documentation
og:title: Page Title — Opik
og:description: One-line summary used for social sharing and previews
og:site_name: Opik Documentation
---
subtitle: ... is an optional field used on concept/overview pages to add a secondary line. Landing/overview pages may also set layout: overview.
Style and voice
Pull examples from v1 pages when unsure — fern/docs/tracing/log_traces.mdx, fern/docs/tracing/concepts.mdx, and fern/docs/quickstart.mdx are good anchors.
- Person: "you" and imperative voice. Professional but approachable.
- Opening: one or two intro sentences before the first
##heading. No inline H1. - Headings:
##for top-level sections,###for subsections. Never introduce an inline#— that collides with the frontmatter title. - Paragraphs: keep them short (2–4 sentences). Mix prose with bullet lists for features, options, and prerequisites.
- Page shape:
- Concept pages start with the why, then definitions.
- How-to pages start with brief context, then the task steps.
- Overview/landing pages lead with a short pitch and a
<CardGroup>of links.
- End with "## Next steps" linking to 2–4 related pages when useful.
Fern MDX components
All examples below are taken from real pages in the repo.
<Tabs> / <Tab> — SDK, language, or environment choice
Use when the whole section varies (not just a code block). Attach language="..." so Fern groups tabs across the site by the reader's last choice.
<Tabs>
<Tab value="Python SDK" title="Python SDK" language="python">
```bash
pip install opik
```
</Tab>
<Tab value="Typescript SDK" title="Typescript SDK" language="typescript">
```bash
npm install opik
```
</Tab>
<Tab value="OpenTelemetry" title="OpenTelemetry">
...
</Tab>
</Tabs>
<Steps> / <Step> — walkthroughs
For quickstarts, installs, and any sequential procedure. title on each <Step> is optional.
<Steps>
<Step title="Install the Opik skill">
```bash
npx skills add comet-ml/opik-skills
```
</Step>
<Step title="Run the integration">
Once the skill is installed, you can add tracing using the following prompt:
```
Instrument my agent with Opik using the /instrument command.
```
</Step>
</Steps>
<CodeBlocks> — multi-language code, identical surrounding prose
Prefer this over <Tabs> when only the code varies.
<CodeBlocks>
```python title="Python"
import opik
opik.configure()
import Opik from "opik";
const client = new Opik();
```
<CardGroup> / <Card> — landing and integration grids
<CardGroup cols={3}>
<Card title="LangChain" href="/integrations/langchain" icon={<img src="/img/tracing/langchain.svg" />} iconPosition="left"/>
<Card title="LlamaIndex" href="/integrations/llama_index" icon={<img src="/img/tracing/llamaindex.svg" />} iconPosition="left"/>
<Card title="Anthropic" href="/integrations/anthropic" icon={<img src="/img/tracing/anthropic.svg" />} iconPosition="left"/>
</CardGroup>
<AccordionGroup> / <Accordion> — FAQs and expandable advanced topics
<AccordionGroup>
<Accordion title="Why use the optimizer?">
The Agent Optimizer provides a unified interface...
</Accordion>
</AccordionGroup>
<Frame> — image wrapper (always wrap images)
<Frame>
<img src="/img/tracing/introduction.png" />
</Frame>
Callouts: <Tip>, <Note>, <Warning>, <Info>, <Callout>
Pick by intent, not aesthetics:
<Tip>— cross-references, shortcuts, "If you're just getting started, see..."<Note>— clarifications and recommendations that aren't risky<Warning>— breaking changes, footguns, prerequisites that will break things<Info>— informational, interchangeable with<Note>in practice<Callout>— catch-all when none of the above fits
<Tip>
If you are just getting started with Opik, we recommend first checking out the [Quickstart](/quickstart) guide.
</Tip>
<Warning>
Note that the authorization header value does not include the `Bearer ` prefix.
</Warning>
Code examples
- Use
<CodeBlocks>for multi-language blocks; use<Tabs>when surrounding prose also varies. - Install commands are inline bash blocks (
pip install opik,npm install opik). - There is no snippet-include system. All code is written inline in MDX.
- Use placeholders for credentials:
<API_KEY>,<TOKEN>,<your-api-key>. Never commit real keys.
Images
- Store under
apps/opik-documentation/documentation/fern/img/<section>/.... - Reference from MDX as
/img/<section>/<file>.png(path is rooted at the docs base). - Never put new assets in
static/img/— that folder is legacy and only kept for external integrations. - Always wrap with
<Frame>. Captions are not a repo convention.
Cross-links
Absolute, slug-based paths only. No relative paths (../foo).
[Python SDK](/reference/python-sdk/overview)
[Log traces](/tracing/log_traces)
[Integrations overview](/integrations/overview)
In-page anchors use the heading slug: [Concepts](#concepts).
Routing: adding a page to latest.yml
Add a page entry under the correct section: (keep the YAML at 2-space indent):
- page: Page Title
path: ../docs-v2/section/page-name.mdx
slug: page-name
If the page also needs to ship in v1, mirror the entry in fern/versions/v1.yml. Leave fern/docs.yml alone.
File naming
- Kebab-case for new files:
getting-started.mdx,log-traces.mdx. - When editing an existing section that uses snake_case (common in v1), match neighbors rather than renaming. Renames require redirect entries in
docs.yml.
Local verification
cd apps/opik-documentation/documentation
npm install # first time only
npm run dev # live-reload preview
Open the rendered page and confirm:
- Frontmatter renders (title shows, no stray H1 in body).
- Every MDX component resolves (no raw
<Tabs>tags visible). - Every link works (no 404s, no
Broken linkwarnings in the terminal). - Images load.
Changelog routing
Pick the changelog target by scope — do not default everything to the root CHANGELOG.md.
CHANGELOG.md(repo root) — self-hosted deployment changelog. Breaking, critical, or security-impacting changes only.apps/opik-documentation/documentation/fern/docs/changelog/*.mdx— general product release notes shown at/docs/opik/changelog. One dated.mdxper entry.apps/opik-documentation/documentation/fern/docs/agent_optimization/getting_started/changelog.mdx— Agent Optimizer version updates (e.g.sdks/opik_optimizerreleases like3.1.0).- Liquibase
changelog.xmlfiles are migration manifests, not user-facing release notes. Do not put prose there. - When unsure, confirm the surface from
fern/docs.ymlbefore editing.
Changelog entry template
### [VERSION] - [DATE]
#### New Features
- **Feature Name**: Brief description
#### Improvements
- **Improvement**: What changed and why
#### Bug Fixes
- **Fix**: What was broken (#issue)
#### Breaking Changes
- **Change**: What breaks, migration steps
Feature documentation checklist
When documenting a new feature, cover:
- User impact — What capability does this add? How do users access it?
- Technical changes — API endpoints and params, SDK methods, config or env vars, migrations.
- Breaking changes — What breaks and the migration path, if any.
Keep it user-facing: avoid implementation detail unless it affects how someone uses the feature.
PR description template
## Summary
- What this PR does (bullet points)
## Test Plan
- How to verify it works
## Related Issues
- Resolves #123
Internationalized READMEs
readme_CN.md, readme_JP.md, readme_KO.md, readme_PT_BR.md, readme_AR.md, readme_DE.md, readme_ES.md, readme_FR.md are AI machine-translated from the English README.md.
- Each non-English README has a blockquote notice at the top warning that it is AI-translated and welcoming improvements. Keep it.
- When the English README changes meaningfully, re-translate the affected files. Do not hand-edit translated READMEs for content changes — update the English source and re-translate.
Forbidden and discouraged
- No real API keys, tokens, or workspace IDs in examples — always placeholders.
- Do not edit
fern/docs/cookbook/*.mdxby hand. Those files are regenerated fromdocs/cookbook/*.ipynbbyupdate_cookbooks.sh. - Do not put new images outside
fern/img/.static/img/is legacy-only and cannot be deleted because of external integrations. - Do not infer URL paths from folder layout — always consult the version YAML.
- Do not add an inline
# H1inside the body — the frontmattertitlealready provides it.
Key files
apps/opik-documentation/documentation/fern/versions/latest.yml— routing for the latest version (edit when adding pages).apps/opik-documentation/documentation/fern/versions/v1.yml— routing for v1 (edit only if the page ships in v1 too).apps/opik-documentation/documentation/fern/docs.yml— global site config (tabs, redirects). Treat as read-only for page adds.apps/opik-documentation/documentation/fern/docs-v2/— target directory for new pages.apps/opik-documentation/documentation/fern/img/— image storage.apps/opik-documentation/documentation/update_cookbooks.sh— regenerates cookbook MDX from notebooks.apps/opik-documentation/AGENTS.md— docs-module contribution rules..github/release-drafter.yml— release notes template.