メインコンテンツへスキップ

インテグレーションガイド

人気のフレームワークと champollion を連携するためのステップバイステップのセットアップ手順です。


API キーの設定

どのフレームワークと連携する場合も、まず翻訳 API キーが必要です。Champollion は2つのプロバイダーをサポートしています。

オプション A: OpenRouter(推奨)

OpenRouter は 200 以上の LLM モデルに対応した統合 API です。無料プランも利用できます。

# Sign up at https://openrouter.ai, then:
export OPENROUTER_API_KEY=sk-or-v1-...

# Or add to .env.local:
OPENROUTER_API_KEY=sk-or-v1-your-key-here

最適な用途: コンテンツ量の多いプロジェクト、Markdown の翻訳、コードブロック・ショートコード・補間変数などのコンテンツ認識シールドが必要なプロジェクト。

オプション B: Google Translate

export GOOGLE_TRANSLATE_API_KEY=...

最適な用途: 大量のキーバリュー形式の文字列ペア(130 以上の言語)。Markdown コンテンツへの使用は推奨しません — Google Translate はコードブロック、ショートコード、補間変数を認識しません。

Google Translate を明示的に使用するには:

champollion sync --method google-translate

ヒント: GOOGLE_TRANSLATE_API_KEY のみが設定されている場合(OpenRouter キーなし)、champollion は自動的に Google Translate に切り替わります。


Hugo(TOML / YAML / Markdown)

プロジェクト構成

Hugo は文字列の翻訳に i18n/ を、ページコンテンツに content/ を使用します。

my-hugo-site/
├── i18n/
│ ├── en.toml ← source of truth
│ ├── fr.toml
│ └── ja.toml
├── content/
│ ├── posts/
│ │ ├── hello.md ← source (English)
│ │ ├── hello.fr.md
│ │ └── hello.ja.md
│ └── about.md
└── .env.local

セットアップ

npm install --save-dev champollion
# .env.local
OPENROUTER_API_KEY=sk-or-v1-your-key-here

champollion.config.json を作成します:

{
"version": 3,
"inputLocale": "en",
"localesDir": "./i18n",
"contentDir": "./content",
"format": "auto",
"languages": ["fr", "de", "ja", "es", "ko", "zh"]
}
champollion sync # sync i18n string files + content files
champollion sync --dry # preview changes without writing

コンテンツ翻訳の詳細

フロントマター: YAML(---)と TOML(+++)の両方のデリミタをサポートしています。デフォルトでは titledescriptionsummarysubtitlecaptionlinkTitle を翻訳します。その他のフィールド(date、draft、tags、weight、slug など)はそのまま保持されます。設定ファイルの translatableFields でカスタマイズできます。

ブロック保護: コードブロック、Hugo ショートコード({{< >}}{{% %}})、インラインコード、生の HTML は Unicode センチネルプレースホルダーを使用して自動的にシールドされます。これらは変更されずにそのまま通過します。

ファイル名の規則: Hugo のファイル名による翻訳パターンに従います:

  • my-post.mdmy-post.fr.md
  • my-post.en.mdmy-post.fr.md(ソースのサフィックスを除去)

既存ファイルのスキップ: 既存の翻訳済みファイルは上書きされません。再翻訳を強制するには、対象ファイルを削除してください。

複数形

TOML および YAML ロケールは CLDR の複数形をサポートしています:

[items]
one = "{{ .Count }} item"
other = "{{ .Count }} items"

内部的には差分処理のために items.oneitems.other として表現され、書き込み時に正しいセクション形式に再シリアライズされます。


next-intl(JSON)

プロジェクト構成

my-app/
├── messages/
│ └── en.json ← source of truth
├── src/
│ ├── i18n/
│ │ ├── routing.ts
│ │ └── request.ts
│ └── middleware.ts
└── .env.local

セットアップ

npm install --save-dev champollion

champollion.config.json を作成します:

{
"version": 3,
"inputLocale": "en",
"localesDir": "./messages",
"languages": ["fr", "de", "ja", "es", "ko", "zh", "pt", "ar"]
}
npx champollion sync

messages/fr.jsonmessages/ja.json などが生成されます — ネストされたキー構造を保持した完全な翻訳ファイルです。next-intl が自動的に読み込みます。

開発ワークフロー

{
"scripts": {
"dev": "champollion watch & next dev",
"i18n:sync": "champollion sync",
"i18n:audit": "champollion audit"
}
}

react-i18next(JSON)

フラットなファイル構成(推奨)

locales/
├── en.json
├── fr.json
└── ja.json
{
"version": 3,
"inputLocale": "en",
"localesDir": "./locales",
"languages": ["fr", "de", "ja"]
}

ネストされたディレクトリ構成

{locale}/{namespace}.json 構成を使用している場合は、フラット化 → 翻訳 → アンフラット化を行う同期スクリプトを作成してください。詳細は react-i18next のドキュメント を参照してください。