Thanks for taking the time to contribute to MDN Web Docs' translated content! 🎉
This document covers project setup steps along with a set of guidelines for contributing to MDN Web Docs translated content. Everyone participating in this project is expected to follow our Code of Conduct.
Before contributing to translated content, we strongly recommend learning about how to contribute to the original (English) content (often referred to as "upstream content"). The upstream contributing guide explains the guidelines and conventions of MDN pages, as well as setup instructions for more significant changes.
We also strongly recommend reading the Translation guidelines.
In addition to the requirements described in the upstream contributing guide, there are additional prerequesites you must have when contributing to this repository:
- Moderate knowledge of the English language: You must have a good enough understanding of the English language to be able to decipher the meaning of a page while translating. (For simple typo fixes, this is not required.)
- Fluency in the downstream locale: You must be able to fluently speak the language you are contributing to.
If you want to make a small change like fixing a typo, the GitHub UI is the easiest way to get started. If you've found a typo on the Simplified Chinese JavaScript landing page, for example, you can propose a fix as follows:
- Sign in to GitHub
- Navigate to https://github.com/mdn/translated-content
- Find the source file
files/zh-cn/web/javascript/index.md
- Click the edit (pencil) button
From there, the GitHub UI will walk you through the rest by creating a fork and a branch to commit your changes to. After you have made changes to your branch, the goal is to open a pull request for your changes to be incorporated.
A pull request represents the work you want to be reviewed, approved, and merged into the main
branch of the MDN repository.
See the Creating a pull request for more details on creating and handling pull requests successfully.
If you're not certain of the changes that you want to make, get in touch with us!
Note: You can click the View the source on GitHub or Edit the page on GitHub link at the bottom of an MDN page to jump directly to the page source on GitHub.
If you want to make changes to more than one file, the GitHub UI is not very efficient because you have to make separate pull requests for each file you want to change.
Instead of using the GitHub UI, you need to use git
or a client like GitHub Desktop or GitHub CLI.
First, you will need to set up the mdn/content
repo locally. If you do not plan to contribute to upstream content, you will not need to fork it as described in its Contributing guide; all you need to do is clone it by running the following command:
git clone https://github.com/mdn/content.git
After the repository has been cloned, follow the steps to prepare the project.
Once that is done, you will also need to fork and clone this repository by following the upstream Contributing guide, replacing content
with translated-content
.
-
Navigate to your local clone of the content repository fork:
cd /path/to/content
-
Next, define an environment variable in a
.env
file calledCONTENT_TRANSLATED_ROOT
containing the path to the translated-content repo'sfiles
directory:echo CONTENT_TRANSLATED_ROOT=/path/to/translated-content/files >> .env
(the
.env
file will be created for you if it does not already exist.) -
Run the command
yarn start
to start the local server atlocalhost:5042
.
This repo has exactly the same folder structure and concepts as the upstream content repo. The main difference is in the setup you need to do before you can start editing. It is mostly the same, but there is a little bit more to consider. Primarily, commands such as yarn content
are only available from the upstream content repo; linting commands are available here, however, as they often use different configuration.
This section describes how to perform the most common types of contributions to MDN translated content.
To fix a typo, refer to the Simple changes section.
To create a new translation for a page that does not yet have one, perform the following steps. For this example, we'll assume you are trying to translate the MDN landing page into French.
-
Find the source file in the upstream content repository. (ex.
/path/to/content/files/en-us/mdn/index.md
) -
Copy the file to the appropriate locale's folder. (ex.
cp /path/to/content/files/en-us/mdn/index.md files/fr/mdn/index.md
) -
Update the front matter of the document.
- Remove excess front matter properties (see Translation guidelines to see which ones should be kept).
- Localize the
title
andshort-title
(if present) - Add a new
l10n.sourceCommit
key, which contains the commit hash of the latest commit that modified the file. You can do this by runninggit log <file>
.
The front matter should look like this:
--- title: Le projet MDN Web Docs slug: MDN l10n: sourceCommit: 048f6b1c75e22103ddb0304d67ee79d6d8a014f0 ---
-
Translate the file, following the Translation guidelines.
-
Create a commit, push your branch and create a pull request!
If a translation is no longer in sync with upstream content (in other words, the English version has changed since the page was translated), the translation will need to be updated.
At the time of writing this document, a massive cleanup of translated content is in progress. Many documents still do not have a l10n.sourceCommit
front matter property. As we update these old files, eventually we aim to have a l10n.sourceCommit
property defined on all files.
XXX Write me...
XXX Write me...
When contributing to the content you agree to license your contributions according to our license.