> docusaurus
Build documentation websites with Docusaurus. Use when a user asks to create a documentation site, build a developer portal, set up API docs, create a knowledge base, add versioned documentation, build a static docs site with search, create a blog alongside docs, or migrate from GitBook or ReadTheDocs. Covers project setup, docs structure, versioning, custom pages, blog, Algolia search, MDX components, and deployment.
curl "https://skillshub.wtf/TerminalSkills/skills/docusaurus?format=md"Docusaurus
Overview
Docusaurus is a static site generator built by Meta specifically for documentation websites. It provides document versioning, sidebar navigation, full-text search (via Algolia), MDX support (React components in Markdown), i18n, and a blog — all out of the box. Used by React, Babel, Jest, Prettier, and hundreds of open-source projects for their documentation.
Instructions
Step 1: Project Setup
# Create new Docusaurus project
npx create-docusaurus@latest my-docs classic
cd my-docs
# Start development server
npm start
# Opens http://localhost:3000
# Build for production
npm run build
# Project structure:
# docs/ — documentation pages (Markdown/MDX)
# blog/ — blog posts
# src/pages/ — custom React pages
# src/css/ — custom styles
# static/ — static assets (images, files)
# docusaurus.config.js — main configuration
# sidebars.js — sidebar navigation structure
Step 2: Write Documentation
---
id: getting-started
title: Getting Started
sidebar_position: 1
description: Quick start guide for installing and configuring the SDK
tags: [quickstart, installation]
---
# Getting Started
Install the SDK via npm:
```bash
npm install @mycompany/sdk
Configuration
Create a config file in your project root:
// sdk.config.js — SDK configuration
export default {
apiKey: process.env.SDK_API_KEY,
region: 'us-east-1',
}
:::tip You can also set configuration via environment variables. :::
:::warning Never commit your API key to version control. :::
:::info For a complete list of options, see the Configuration Reference. :::
### Step 3: Configure Sidebar Navigation
```javascript
// sidebars.js — Define the documentation sidebar structure
/** @type {import('@docusaurus/plugin-content-docs').SidebarsConfig} */
const sidebars = {
docs: [
'intro',
{
type: 'category',
label: 'Getting Started',
items: ['getting-started', 'installation', 'configuration'],
collapsed: false,
},
{
type: 'category',
label: 'Guides',
items: [
'guides/authentication',
'guides/data-fetching',
'guides/error-handling',
'guides/deployment',
],
},
{
type: 'category',
label: 'API Reference',
items: ['api/client', 'api/hooks', 'api/utilities'],
},
],
}
module.exports = sidebars
Step 4: Site Configuration
// docusaurus.config.js — Main site configuration
/** @type {import('@docusaurus/types').Config} */
const config = {
title: 'My SDK Documentation',
tagline: 'Build amazing things with our SDK',
url: 'https://docs.mycompany.com',
baseUrl: '/',
onBrokenLinks: 'throw',
onBrokenMarkdownLinks: 'warn',
i18n: { defaultLocale: 'en', locales: ['en'] },
presets: [
['classic', {
docs: {
sidebarPath: './sidebars.js',
editUrl: 'https://github.com/mycompany/docs/tree/main/',
showLastUpdateTime: true,
showLastUpdateAuthor: true,
},
blog: {
showReadingTime: true,
blogSidebarCount: 10,
},
theme: { customCss: './src/css/custom.css' },
}],
],
themeConfig: {
navbar: {
title: 'My SDK',
logo: { alt: 'Logo', src: 'img/logo.svg' },
items: [
{ type: 'docSidebar', sidebarId: 'docs', position: 'left', label: 'Docs' },
{ to: '/blog', label: 'Blog', position: 'left' },
{ type: 'docsVersionDropdown', position: 'right' },
{ href: 'https://github.com/mycompany/sdk', label: 'GitHub', position: 'right' },
],
},
footer: {
style: 'dark',
links: [
{ title: 'Docs', items: [{ label: 'Getting Started', to: '/docs/getting-started' }] },
{ title: 'Community', items: [{ label: 'Discord', href: 'https://discord.gg/...' }] },
],
},
algolia: {
appId: 'YOUR_ALGOLIA_APP_ID',
apiKey: 'YOUR_ALGOLIA_SEARCH_KEY',
indexName: 'my-docs',
},
},
}
module.exports = config
Step 5: Document Versioning
# Create a new version snapshot (freezes current docs/)
npm run docusaurus docs:version 1.0
# Directory structure after versioning:
# docs/ — "next" (unreleased) docs
# versioned_docs/version-1.0/ — frozen v1.0 docs
# versioned_sidebars/ — frozen v1.0 sidebars
# Create another version
npm run docusaurus docs:version 2.0
# Users can switch between versions via the dropdown
Step 6: MDX Components
---
title: Interactive Examples
---
import Tabs from '@theme/Tabs'
import TabItem from '@theme/TabItem'
# Installation
<Tabs>
<TabItem value="npm" label="npm" default>
```bash
npm install @mycompany/sdk
```
</TabItem>
<TabItem value="yarn" label="yarn">
```bash
yarn add @mycompany/sdk
```
</TabItem>
<TabItem value="pnpm" label="pnpm">
```bash
pnpm add @mycompany/sdk
```
</TabItem>
</Tabs>
## Custom Components
export const Highlight = ({children, color}) => (
<span style={{ backgroundColor: color, padding: '4px 8px', borderRadius: '4px', color: '#fff' }}>
{children}
</span>
)
Status: <Highlight color="#25c2a0">Stable</Highlight> <Highlight color="#1877F2">v2.0+</Highlight>
Step 7: Deploy
# Build static site
npm run build
# Output in build/ — deploy anywhere (Vercel, Netlify, GitHub Pages, S3)
# GitHub Pages deployment
GIT_USER=mycompany npm run deploy
# Vercel — just connect the repo, it auto-detects Docusaurus
# Netlify — build command: npm run build, publish directory: build
Examples
Example 1: Create documentation for an open-source library
User prompt: "Set up a documentation site for my npm package. I need a getting started guide, API reference, versioned docs, and a blog for release notes."
The agent will:
- Scaffold a Docusaurus project with the classic preset.
- Create the docs structure: intro, getting-started, guides/, api/.
- Set up sidebars with logical grouping.
- Add versioning for v1.0.
- Configure Algolia DocSearch for full-text search.
- Add GitHub Pages deployment to CI.
Example 2: Build an internal developer portal
User prompt: "We have 5 microservices. Build a single docs site that documents all of them with separate sections, shared architecture diagrams, and an internal blog."
The agent will:
- Create a multi-instance docs setup (one docs folder per service).
- Add a shared architecture section with embedded diagrams (Mermaid).
- Configure internal blog for architecture decisions and RFCs.
- Deploy behind VPN/auth for internal access only.
Guidelines
- Use the
classicpreset for most documentation sites — it includes docs, blog, pages, and search out of the box. - Structure docs in a flat hierarchy when possible — deeply nested sidebars are hard to navigate. 2-3 levels max.
- Enable
showLastUpdateTimeandshowLastUpdateAuthor— it builds trust with readers and helps identify stale docs. - Set
onBrokenLinks: 'throw'to catch broken internal links during build. This prevents deploying docs with dead links. - Use MDX sparingly — most docs should be plain Markdown for contributor accessibility. Save MDX for interactive examples and complex layouts.
- Apply for Algolia DocSearch (free for open-source) for production search. For internal docs, use the local search plugin.
> related_skills --same-repo
> zustand
You are an expert in Zustand, the small, fast, and scalable state management library for React. You help developers manage global state without boilerplate using Zustand's hook-based stores, selectors for performance, middleware (persist, devtools, immer), computed values, and async actions — replacing Redux complexity with a simple, un-opinionated API in under 1KB.
> zoho
Integrate and automate Zoho products. Use when a user asks to work with Zoho CRM, Zoho Books, Zoho Desk, Zoho Projects, Zoho Mail, or Zoho Creator, build custom integrations via Zoho APIs, automate workflows with Deluge scripting, sync data between Zoho apps and external systems, manage leads and deals, automate invoicing, build custom Zoho Creator apps, set up webhooks, or manage Zoho organization settings. Covers Zoho CRM, Books, Desk, Projects, Creator, and cross-product integrations.
> zod
You are an expert in Zod, the TypeScript-first schema declaration and validation library. You help developers define schemas that validate data at runtime AND infer TypeScript types at compile time — eliminating the need to write types and validators separately. Used for API input validation, form validation, environment variables, config files, and any data boundary.
> zipkin
Deploy and configure Zipkin for distributed tracing and request flow visualization. Use when a user needs to set up trace collection, instrument Java/Spring or other services with Zipkin, analyze service dependencies, or configure storage backends for trace data.