This repository generates the documentation available at https://docs.mattermost.com/. All documentation is available under the terms of a Creative Commons License.
If you have any questions, sign up to community.mattermost.com and join the Documentation channel.
You can edit or create Mattermost documentation directly in GitHub or by downloading the repo onto your machine and using an editor such as Atom. Consult the Mattermost Documentation Style Guide and reStructuredText Markup section for stylistic and technical guidance.
If this is your first time contributing to Mattermost, first read the Mattermost Contributor Agreement and sign it (at the bottom of the page), so you can be added to the Mattermost Approved Contributor List.
The quickest way to begin is editing directly on GitHub on your fork of the Mattermost docs repo. Click the Edit icon on the top right corner of the page you want to edit in the Mattermost documentation.
If this the first time you're contributing, click Edit the file in your fork of this project (pencil icon) on the top right corner to create a fork.
- When you're ready to submit your changes, add a descriptive title and comments to summarize the changes made.
- Select Create a new branch for this commit and start a pull request.
- Check the Propose file change button.
- Scroll down to compare changes with the original document.
- Select Create pull request.
Labels are used to track the lifecycle and status of a pull request. Using the correct labels helps with managing workflows and ensuring that content is edited, merged and released at the correct time. Take a look at the Labels page for information about how and when to use which labels.
Once a pull request is submitted, multiple committers may comment on it and provide edits or suggestions which you can commit directly. You can also add line comments. Take a look at Commenting on pull requests for more details.
Once a pull request has been submitted and the correct label assigned, the review process begins. This includes aligning the content with the Style Guide, validating processes, and tagging any other relevant committers. You can read more about the review process and expectations here.
Once the review process is complete and depending on the type of issue it is (e.g., a typo fix vs. a new feature), the change is either merged into master and pushed immediately or merged into the release branch and pushed in alignment with the release. The branch is then deleted.
Any merged PRs with an Editor Review or Reviews Complete label will be processed by the editor reviewer to ensure the documentation is correctly formatted at https://docs.mattermost.com/.
If you've downloaded the repo and are editing Mattermost documentation on your local machine, you can generate the HTML files from markdown in the /source
directory. You can review them before you commit changes or create pull requests.
- Download the Mattermost docs repo onto a machine with Python installed.
- Install pipenv:
pip install pipenv
. cd
into the cloned repository.- Install the required packages:
pipenv install
. - Build the doc set using
make html
. This generates files in/build
directory. - Navigate to the
/build
directory to preview the page/s you've edited.
The build process may generate this error: WARNING: toctree contains reference to document u'foo' that doesn't have a title: no link will be generated
. It can be ignored as it does not negatively impact the documentation.
- Install sphinx-intl:
pip install sphinx-intl
. cd
into the cloned repository.- Install the required packages:
pipenv install
. - Extract translatable messages into pot files:
make gettext
. - Generate po files:
sphinx-intl update -p build/locale -l it
. - translate po files in
source/locale/it/LC_MESSAGES
. - Build translated document:
make -e SPHINXOPTS="-D language='it'" html
.
For more informations please refer to https://www.sphinx-doc.org/en/master/usage/advanced/intl.html