zudo-cloudflare-wisdom

Type to search...

to open search from anywhere

/CLAUDE.md

作成2026年4月4日Takeshi Takatsudo

CLAUDE.md at /CLAUDE.md

Path: CLAUDE.md

zudo-cloudflare-wisdom

Takazudo’s Cloudflare dev notes, built with zudo-doc (Astro, MDX, Tailwind CSS v4).

Commands

pnpm dev          # Start Astro dev server (port 4821)
pnpm build        # Build static site to dist/
pnpm preview      # Preview built site
pnpm check        # Astro type checking
pnpm format:md    # Format MDX files
pnpm b4push       # Pre-push validation (format + typecheck + build)

Content Structure

  • English (default): src/content/docs/ -> /docs/...
  • Japanese: src/content/docs-ja/ -> /ja/docs/...
  • Japanese docs should mirror the English directory structure

Bilingual rule: When creating or updating any doc page, ALWAYS update both the English (docs/) and Japanese (docs-ja/) versions in the same PR. Keep code blocks identical between languages — only translate surrounding prose. If a Japanese version does not yet exist, create it.

Exception: Pages with generated: true in frontmatter (e.g., claude-resources auto-generated pages) do not require Japanese translations.

Content Categories

Top-level directories under src/content/docs/. Directories with header nav entries are mapped via categoryMatch in src/config/settings.ts:

  • getting-started/ - Overview, what this site covers, Cloudflare account setup
  • pages/ - Cloudflare Pages deployment, _redirects, base paths, preview deploys, Pages Functions
  • workers/ - Standalone Workers, wrangler config, deployment, compatibility dates
  • storage/ - KV, D1, R2 bindings and usage patterns
  • cicd/ - GitHub Actions deploy workflows, preview per PR, IFTTT notifications
  • recipes/ - Real-world patterns (Astro + Pages, search APIs, auth, multi-site)
  • claude/ - Claude Code integration docs

Auto-generated directories (no header nav entry, managed by claude-resources integration):

  • claude-md/ - CLAUDE.md file documentation (noPage: true)
  • claude-skills/ - Claude Skills documentation (noPage: true)

Writing Docs

All documentation files use .mdx format with YAML frontmatter.

Frontmatter Fields

Schema defined in src/content.config.ts:

FieldTypeRequiredDescription
titlestringYesPage title, rendered as the page h1
descriptionstringNoSubtitle displayed below the title
sidebar_positionnumberNoSort order within category (lower = higher). Always set this for predictable ordering
sidebar_labelstringNoCustom text for sidebar display (overrides title)
tagsstring[]NoCross-category grouping tags
draftbooleanNoExclude from build entirely
unlistedbooleanNoBuilt but noindexed, hidden from sidebar/nav
hide_sidebarbooleanNoHide the left sidebar, center content
hide_tocbooleanNoHide the right-side table of contents
standalonebooleanNoHidden from sidebar nav but still indexed
slugstringNoCustom URL slug override
generatedbooleanNoBuild-time generated content (skip translation)
search_excludebooleanNoExclude from search results
pagination_nextstring/nullNoOverride next page link (null to hide)
pagination_prevstring/nullNoOverride prev page link (null to hide)

Content Rules

  • No h1 in content: The frontmatter title is automatically rendered as the page h1. Start your content with ## h2 headings. Do not write # h1 in the MDX body.
  • Always set sidebar_position: Without it, pages sort alphabetically which is unpredictable. Use integers starting from 1.
  • Kebab-case file names: Use my-article.mdx, not myArticle.mdx or my_article.mdx.

Linking Between Docs

Use relative file paths with the .mdx extension:

[Link text](./sibling-page.mdx)
[Link text](../other-category/page.mdx)
[Link text](../other-category/page.mdx#anchor)

The remark plugin resolves these during build. External links use standard URLs.

Admonitions

Available globally without imports. Two syntax forms:

Directive syntax (preferred for longer content):

:::note[Custom Title]
Content here.
:::

JSX syntax (for inline use):

<Note>Short note content.</Note>

Types: <Note>, <Tip>, <Info>, <Warning>, <Danger>

Mermaid Diagrams

Mermaid is enabled. Use fenced code blocks:

```mermaid

graph TB
  A --> B

```

HtmlPreview Component

For interactive HTML/CSS/JS previews with code display:

<HtmlPreview html="<div>Hello</div>" css="div { color: red; }" />

Use js/displayJs props for JavaScript demos.

Navigation is filesystem-driven. Directory structure directly becomes sidebar navigation.

  • Pages are ordered by sidebar_position (ascending). Without it, alphabetical order is used.
  • Category index pages (index.mdx) control category position via their own sidebar_position.

Category Index Pages

Create index.mdx in a category directory when you want custom intro copy, description, or explicit sidebar ordering. The framework auto-generates category index pages when missing, but explicit ones give better control.

Category Configuration

Use _category_.json for category-level metadata when needed:

{
  "label": "Category Name",
  "position": 900,
  "description": "Category description",
  "noPage": true
}

The noPage: true flag means the category has no landing page (just groups items).

Header Navigation

Defined in src/config/settings.ts via headerNav. Each item maps to a top-level content directory via categoryMatch:

{ label: "Overview", path: "/docs/getting-started", categoryMatch: "getting-started" }

categoryMatch must be a single top-level directory name. Adding a new header nav item requires editing settings.ts.

Content Creation Workflow

Adding a New Article

  1. Create the English .mdx file in the appropriate category under src/content/docs/
  2. Add frontmatter with at least title and sidebar_position
  3. Write content starting with ## h2 headings (not # h1)
  4. Create the matching Japanese file under src/content/docs-ja/ with the same path
  5. Keep code blocks, Mermaid diagrams, and <HtmlPreview> blocks identical — only translate prose
  6. Run pnpm format:md to format the MDX files
  7. Run pnpm build to verify the site builds correctly

Adding a New Category

  1. Create the directory under src/content/docs/ (kebab-case)
  2. Create index.mdx with title, description, and sidebar_position
  3. Add a headerNav entry in src/config/settings.ts with categoryMatch pointing to the directory name
  4. Mirror the directory structure under src/content/docs-ja/
  5. Run pnpm build to verify

MDX Components

Available globally in MDX without imports:

  • <Note>, <Tip>, <Info>, <Warning>, <Danger> - Admonitions
  • <HtmlPreview> - Interactive HTML/CSS/JS preview with code display

Typography

  • Futura for page h1 titles and header site name (font-futura class)
  • Noto Sans JP for body text
  • Headings use font-weight 400 (normal), not bold

Doc Skill (cloudflare-wisdom)

The cloudflare-wisdom skill (/.claude/skills/cloudflare-wisdom/SKILL.md) is generated by pnpm setup:doc-skill (runs scripts/setup-doc-skill.sh). It is gitignored — do NOT track it in git or edit it directly. To update the skill content, edit the generator script and re-run pnpm setup:doc-skill.

Site Config

  • Base path: /pj/zudo-cloudflare
  • Settings: src/config/settings.ts

CI/CD

  • PR checks: typecheck + build + Cloudflare Pages preview
  • Main deploy: build + Cloudflare Pages production + IFTTT notification
  • Secrets: CLOUDFLARE_ACCOUNT_ID, CLOUDFLARE_API_TOKEN, IFTTT_PROD_NOTIFY