- 
                Notifications
    You must be signed in to change notification settings 
- Fork 26
Translation Guide
Help us make the Scrum Guide Expansion Pack accessible to everyone worldwide by -Contributing-to-the-Scrum-Guide-Expansion-Pack Translation-Guide!
Please read the Code of Conduct for Translation Contributors before starting.
Best for: Translators familiar with Git, GitHub, and the Pull Request Workflow.
Process:
- Fork the repository
- Create translation files with our Automated Setup
- Collaborate with other translators
- Submit Pull Request for review
Best for: Translators who are non-technical and dont want to collaborating with pull requests.
Process:
- Download translation templates
- Work independently or collaborate via email/messaging
- Submit completed Translation-Guide via GitHub Issues
- We'll create the Pull Request for community review
To add a new language to the site, you'll need to translate:
- 
File: site/content/guide/index.{LANG}.md
- Content: The complete Scrum Guide Expansion Pack document
- Size: ~900 lines of Markdown content
- 
File: site/i18n/{LANG}.yaml
- Content: Navigation, buttons, labels, and interface text
- Size: ~40 translation keys
- Creator pages in site/content/creators/
- Download page content
- GitHub account
- Basic understanding of Git/GitHub
- Markdown knowledge helpful but not required
- 
Fork the repository
- Go to ScrumGuide-ExpansionPack
- Click "Fork" button
- Clone your fork locally
 
git clone https://github.com/YOUR-USERNAME/ScrumGuide-ExpansionPack.git
cd ScrumGuide-ExpansionPackgit checkout -b translation/add-{LANG}-languageReplace {LANG} with your language code (e.g., pt for Portuguese, ja for Japanese).
Prerequisites: PowerShell 7+ (Windows, macOS, or Linux)
Use our automated translation template script to set up all necessary files:
⚠️ Note: The script will automatically install the requiredpowershell-yamlmodule if it's not already available.
# Basic usage
.\scripts\Create-TranslationTemplate.ps1 -LanguageCode "de" -LanguageName "German"
# Advanced usage with custom settings
.\scripts\Create-TranslationTemplate.ps1 -LanguageCode "es" -LanguageName "Spanish" -Title "Guía Scrum Paquete de Expansión" -Weight 3 -ForceWhat the script does:
- ✅ Adds language -Configuration-Reference to hugo.yaml
- ✅ Creates site/i18n/{LANG}.yamlfrom English template
- ✅ Creates all translated content files (*.{LANG}.md)
- ✅ Sets up proper frontmatter with placeholders
- ✅ Validates the complete setup
- ✅ Provides next steps guidance
🕒 Time savings: The script reduces setup time from ~30 minutes manual work to ~2 minutes automated setup.
Script Parameters:
- 
LanguageCode- ISO language code (e.g., 'de', 'es', 'fr')
- 
LanguageName- Display name (e.g., 'German', 'Spanish')
- 
Title- Translated site title (optional)
- 
Description- Translated site description (optional)
- 
Keywords- Translated site keywords (optional)
- 
Weight- Language menu order (optional, auto-calculated)
- 
Force- Overwrite existing files
💡 Don't have PowerShell? Install it from Microsoft's official guide - it's free and available for Windows, macOS, and Linux.
If you prefer manual setup or don't have PowerShell:
A. Main Guide Translation
- Copy the English guide:
cp site/content/guide/index.md site/content/guide/index.{LANG}.md- Edit the frontmatter in site/content/guide/index.{LANG}.md:
---
title: "Your Translated Title"
description: "Your translated description"
# ... translate other metadata
---- Translate the entire content while preserving:
- Markdown formatting (##,**bold**,[links](https://github.com/ScrumGuides/ScrumGuide-ExpansionPack/blob/main/docs/url))
- Hugo shortcodes
- Reference numbers (40), (58), etc.
- HTML comments and IDs
 
- Markdown formatting (
B. UI Translation File
- Copy the English Translation-Guide:
cp site/i18n/en.yaml site/i18n/{LANG}.yaml- Translate each entry in site/i18n/{LANG}.yaml:
# Example - keep the ID, translate the text
- id: read_online_title
  translation: "Your translated text here"C. Add Language to Hugo -Configuration-Reference
Add your language to site/hugo.yaml in the languages: section:
languages:
  # ... existing languages
  { LANG }:
    languageName: Your Language Name
    weight: 2 # Adjust as needed
    title: Your Translated Site Title
    params:
      description: "Your translated description"
      keywords: "Your translated keywords"- Install Hugo (see -Development-Guide Guide)
- Start the -Development-Guide server:
cd site
hugo server --config hugo.yaml,hugo.local.yaml- 
View your translation:
- Navigate to http://localhost:1313/{LANG}/
- Check all pages and UI elements
- Verify language switching works correctly
 
- Navigate to 
- Commit your changes:
git add .
git commit -m "Add {LANG} translation"
git push origin translation/add-{LANG}-language- 
Create Pull Request: - Go to your fork on GitHub
- Click "New Pull Request"
- Use title: "Add {Language Name} translation"
- Include translation details in description
 
- 
Review Process: - Creators and community will review
- Native speakers may suggest improvements
- Collaborate on refinements
- Merge when approved
 
💡 Tip: Even if you're using the manual workflow, you can still use our PowerShell automation script to generate the template files - just fork the repo temporarily, run the script, then download the generated files to work with locally.
- 
Download files to translate: 
- 
Save locally with your language code: - 
index.{LANG}.md(e.g.,index.pt.md)
- 
{LANG}.yaml(e.g.,pt.yaml)
 
- 
- 
Main Guide ( index.{LANG}.md):- Translate title and description in the frontmatter
- Translate all body content
- Keep all Markdown formatting intact
- Preserve reference numbers and links
 
- 
UI File ( {LANG}.yaml):- Translate only the text after translation:
- Keep the id:values unchanged
- Maintain YAML formatting
 
- Translate only the text after 
- Share files with other translators via email or messaging
- Use Google Docs or similar for collaborative editing
- Coordinate with existing translation communities
- 
Create GitHub Issue: - Go to Issues page
- Click "New Issue"
- Title: "Translation Submission: {Language Name}"
 
- 
Include in issue: - Language name and code
- Attach your translated files
- List any collaborators to credit
- Note any questions or concerns
 
- 
We'll handle the rest: - Create proper Git commits
- Set up Pull Request
- Coordinate community review
- Handle technical integration
 
Use ISO 639-1 two-letter codes when available, or ISO 639-2 three-letter codes for languages not covered:
Two-letter codes:
- 
de- German (Deutsch)
- 
es- Spanish (Español)
- 
fr- French (Français)
- 
pt- Portuguese
- 
ja- Japanese
- 
zh- Chinese
Three-letter codes:
- 
tlh- Klingon (example implementation available)
- 
Preserve Structure: - Keep all headings, links, and formatting
- Maintain reference numbers exactly: (40), (58)
- Don't translate technical terms unnecessarily
 
- 
Cultural Adaptation: - Adapt examples to local context when appropriate
- Maintain the professional, educational tone
- Consider regional business practices
 
- 
Consistency: - Use consistent terminology throughout
- Create a glossary for key Scrum terms
- Follow existing translation patterns if available
 
- Accuracy: Faithful to original meaning
- Clarity: Clear and understandable for target audience
- Completeness: All content translated
- Formatting: Markdown and YAML syntax preserved
For using the automated translation setup script:
- Windows: Install PowerShell 7+
- macOS: Install PowerShell on macOS
- Linux: Install PowerShell on Linux
- -Development-Guide Setup
- -Contributing-to-the-Scrum-Guide-Expansion-Pack Guidelines
- Content Management
- Review the existing Klingon translation (tlh) as an example implementation
- Check if your language is already in progress
- Join our community discussions
- GitHub Users: Comment on your Pull Request
- Community Contributors: Comment on your submission issue
- General Questions: Create a new issue
- Connect with other translators in your language
- Share resources and terminology decisions
- Coordinate on quality review
All translation contributors will be:
- Credited in the translated version
- Listed in project contributors
- Recognized in release notes
- Invited to join the translation team
Thank you for helping make Scrum knowledge accessible worldwide! 🌍