Ga naar hoofdinhoud

Framework-integratie

Stapsgewijze configuratie voor i18n-rosetta met populaire frameworks.

Hugo (TOML / YAML / Markdown)

Projectstructuur

Hugo gebruikt i18n/ voor stringvertalingen en content/ voor pagina-inhoud:

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

Configuratie

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

Details van contentvertaling

Front matter: Ondersteunt zowel YAML- (---) als TOML-scheidingstekens (+++). Vertaalt standaard title, description, summary, subtitle, caption en linkTitle. Alle andere velden (date, draft, tags, weight, slug, enz.) blijven behouden. U kunt dit aanpassen met translatableFields in uw configuratie.

Blokbescherming: Codeblokken, Hugo-shortcodes, inline code en ruwe HTML worden automatisch afgeschermd met behulp van Unicode-sentinel-placeholders. Deze worden ongewijzigd doorgegeven.

Bestandsnaamconventie: Volgt Hugo's patroon voor vertaling via bestandsnamen:

  • my-post.mdmy-post.fr.md
  • my-post.en.mdmy-post.fr.md (verwijdert het achtervoegsel van de bron)

Bestaande overslaan: Bestaande vertaalde bestanden worden nooit overschreven. Verwijder een doelbestand om een hervertaling af te dwingen.

Meervoudsvormen

TOML- en YAML-locales ondersteunen CLDR-meervoudsvormen:

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

Intern weergegeven als items.one en items.other voor diffing, en vervolgens bij het wegschrijven opnieuw geserialiseerd naar het correcte, in secties verdeelde formaat.