Skip to content

Latest commit

 

History

History
283 lines (183 loc) · 21.5 KB

File metadata and controls

283 lines (183 loc) · 21.5 KB

Technical Writing Team Handbook

Technical Writing Handbook

Mattermost Technical Writers focus primarily on writing, editing, structuring, and maintaining Mattermost technical and product documentation, end user documentation for Mattermost Channels, Boards, and Playbooks, as well as developer documentation and the company Handbook. Technical Writers also manage in-product microcopy, provide editorial reviews for all documentation across the organization, and work closely with the community to improve documentation.

Areas of responsibility (AORs)

Documentation and technical writing at Mattermost covers (but isn't limited to) the following verticals:

  • Channels
    • Mattermost Cloud
    • Self-managed deployments
    • Messaging features and functionality
  • Playbooks
  • Boards
  • Growth
    • Customer Portal
    • Telemetry
  • Apps Framework and Marketplace

Other areas of documentation include:

  • Mattermost Handbook
  • Integrations (developer documentation, plugin documentation, and developer journey)
  • Documentation metrics:
    • Docs page ratings via Google Analytics
    • Google Analytics metrics for page visits, read times, and bounce rates
    • Customer feedback analysis
    • Metrics dashboards using RudderStack
  • In-product messaging and interface
  • GitLab documentation for:
  • Developer documentation for:
  • Community and doc review process
    • Process for Doc Up plugin
    • Docs review and release coordination
    • Community Help Wanted doc issues
  • Content and processes
    • PR reviews across the organization
    • Documentation processes for release PRs

Please reach out to the Documentation Working Group for any questions.

How to contribute to the documentation

Our documentation is open to contributions from anyone. The basic outline for getting started with contributions is provided in the README of the docs repo. If you have write access to the repo, you can create a branch off master and work on that.

Once complete, submit your Pull Request (PR). Ensure that you assign appropriate approvers and labels - if you've forked the repo or don't have the correct repo permissions you may not be able to do this, so you can skip this step. Read more about the review process here - it applies to various types of contributions including documentation.

PR tips and best practices

  • Try to submit files in batches rather than single PRs for each file update. This reduces the PR load and also groups your changes more effectively.
  • When there are lots of changes requested, especially on a docs PR that doesn't require QA testing, you can use the "Add suggestion to batch" feature in GitHub to commit all of the suggestions at once. You need to be on the Files changed tab to use this feature, though it's also shown on the Conversation tab. By batching your suggestions, you can use one commit message such as "Added batch suggestions from @Carrie Warner". This just makes the commit history of the PR a lot more readable and useful for everyone reviewing it.
  • Descriptive PR titles and commit messages go a long way, especially when the PR is referenced in the future. The default PR titles that GitHub gives us like "Updated README.md" are not very helpful because there's no way to know the purpose of the PR by reading the title. For example, if the whole file was translated to Japanese because we realize that's our main audience, that information isn't obvious unless you open the PR and read it - or if it's in the PR title.

Style Guide and UI writing guides

Our [Documentation Style Guide] is a guide to writing Mattermost product documentation and includes guidelines around punctuation, casing, and how to format files. We also have a guide for writing UI copy which includes tip, best practices, and examples.

Feature documentation process: Product Manager and Developers

Submitting feature documentation

Feature documentation is a joint effort between Product Managers, Developers, and Technical Writers. In the same way that we want to empower everyone to contribute to our documentation, Product Managers are encouraged to write MVP documentation for their product/feature.

Feature changes and new features first exist as code PRs. These PRs form the basis of whatever changes are being documented. If a code PR is for a new feature, major update to an existing feature, or a fix that impacts the current documentation, it's recommended that a documentation update is made. The Technical Writers work closely with their development teams to ensure that these types of changes are documented accordingly.

One way we do this is by using the Docs/Needed label. When a code PR is submitted, that may have documentation impact, the Docs/Needed label is added. The assigned writer then reviews the PR and, if there are documentation changes needed, opens a PR in the docs repo with reference to the code PR.

As a developer you are also welcome to update the documentation yourself in one of the following ways:

  • Update the relevant page on docs.mattermost.com, and submit a PR for that. This PR is submitted to the docs repo, reviewed by the relevant team members, and merged from there.
  • Submit your documentation as a new file, including the context and changes, any code samples, and processes. You can submit this as part of your code PR, or you can open a new PR in the docs repo and include a link to your open code PR.

We don't expect a huge body of documentation or that it's perfectly-written - but rather a clear, concise outline of the change which can be added to our documentation. The content can be provided as a list, rough notes, or you can use the example below for content and structural guidance if your documentation is quite detailed.

Note: Due to the cadence of the release cycle, feature documentation needs to be complete and submitted as per the release process to allow sufficient time for review and to ensure it's included in the release documentation update.

The supplied content can be provided informally, in bullet points, or rough notes in a Google Doc/on the PR itself. Refinements are made collaboratively.

Feature documentation MVP (PMs)

This is a guideline of what MVP feature documentation can include. Requirements vary based on the scope of the change, so not everything will always be needed:

  • A link to the feature/product's tech spec.
  • Links to any relevant Jira/GitHub issues.
  • A description of the product/feature/update which forms the basis of the documentation.
  • Steps for any processes or procedures (configuration of a feature, troubleshooting, etc).
  • Any FAQs or troubleshooting questions if relevant.
  • Any limitations, issues, or known problems.
  • Configuration settings and examples for the config.json file if relevant.
  • (If possible) Suggestions of where in the docs the content should go.

When the content has been refined and approved in draft format:

  • The Product Manager/Technical Writer creates a branch off the relevant documentation release branch.
  • The documentation is updated with the approved content in that branch.
    • If there are multiple pages to update for a specific feature/change please keep them all in the same branch for ease of management.
  • The PR is submitted and relevant reviewers added, including an editor (not the Technical Writer who wrote the docs), for final review.
    • Include the link to the server/webapp repo issue in your PR for reference purposes.
  • Once all reviews are complete, the PR is marked as Reviews Complete and merged into the documentation release branch by @amyblais.

You can read more about the review process here.

You can find additional guidance around formatting here.

Once your PR is submitted, there's a review process that includes an editorial review, a PM review, and sometimes a dev review. During the editorial review, editors may make punctuation and/or terminology changes and commit them to save time on the review process. This only applies to punctuation/terminology - content suggestions and questions will follow the usual review and discussion process.

Once the review is complete, we'll move your contribution to the appropriate part of docs.mattermost.com (if it's not there already) and then merge it. We'll share the URL and you can edit it at any time if you need to.

Submit documentation with your PR: Community

We want to empower everyone to contribute to our documentation, and be comfortable submitting documentation for contributions. As such, we don't expect every contribution to adhere to our style guide when first submitted.

During the review process the editorial team also provides feedback on style elements to bring the submission in line with the Documentation Style Guide.

Here are some guidelines:

  • When submitting a code PR, please include updated documentation if applicable.
  • The documentation update can be in the form of a bullet list or an outline.
  • Label the PR as Docs Needed/Editor Review and tag @justinegeffen or @carriewarnermm.
  • The documentation you've submitted will be reviewed.
  • At times, the editors may make and commit stylistic changes (such as punctuation) but any content changes will be added as a suggestion for the submitter's consideration.
  • Once the PR is approved, it will be merged, and the documentation will be updated.

You can read more about the review process here.

Note: This process does not apply to the API Documentation requirements as it is updated automatically and isn't part of the documentation process.

Add reviewers to PRs

Mattermost documentation covers a number of different topics. For documentation, the following reviewers are recommended:

Editor Review

  • Carrie Warner (@cwarnermm)
  • Justine Geffen (@justinegeffen)

Product Manager Review

  • Channels: Katie Wiersgalla (@wiersgallak)
  • Security: Katie Wiersgalla (@wiersgallak)
  • Cloud: Katie Wiersgalla (@wiersgallak)
  • Playbooks: Ian Tao (@tao)
  • Boards: Winson Wu @winsonwu)
  • Licensing: Jason Blais(@jasonblais)
  • Mobile and desktop app: Eric Sethna (@esethna)
  • Apps and Marketplace: Aaron Rothschild (@aaronrothschild)
  • Handbook and Process; Community: Jason Blais (@jasonblais)

Dev Review

If your change requires dev review add the developer/s you've been working with as the reviewer/s. If you're unsure who to add as a dev reviewer you can select one of the team leads below:

  • Boards: Scott Bishel (@sbishel)
  • Integrations: Catalin Tomei (@catalintomai)
  • Playbooks: Jesse Hallam (@lieut-data)
  • Channels: Martin Kraft (@mkraft)
  • Growth: Maria Nuñez (@marianunez)
  • SRE: Joram Wilander (@jwilander) (\interm)
  • Cloud Platform: Joram Wilander (@jwilander)
  • Mobile: Elias Nahum (@enahum)
  • Web App and Desktop App: Dean Whillier (@deanwhillier)
  • Server/infra: Joram Wilander (@jwilander)
  • Cloud: Joram Wilander (@jwilander)
  • Security: Daniel Schalla (@dschalla)
  • QA: Saturnino Abril (@saturninoabril)
  • Handbook and Process: Jason Blais (@jasonblais)

The full list of R&D teams is available here.

Submit a documentation request

If you have documentation requests or questions, you can submit a request via the Doc Up plugin or submit a GitHub issue directly via the Docs repo. All issues are reviewed and feedback provided.

While we do accept ad-hoc requests for work, we appreciate this process being followed as it helps us prioritize and ensure coverage for all work.

Via Doc Up

Requests for documentation can be made within community.mattermost.com, using the Doc Up plugin embedded in the post menu. Access the Doc Up plugin by hovering over a message and selecting the ... menu.

When you select Doc Up and choose Admin as the issue type, an issue is generated in the GitHub docs repo, and added to the issues list. An update is listed in the Documentation channel, with the issue link. You can also select Developer or Company Handbook to direct the Doc Up request to the appropriate repo.

As the issues are open to the community, the more information provided in the issue the better.

Review the issue in the docs repo, developer documentation repo, or handbook repo and add any links to appropriate documentation and/or Jira tickets. This ensures that the assignee is able to take on and complete the work within the turnaround times.

Create a GitHub issue

If you have feedback on our documentation, a suggestion, or new content you'd like to add but don't know where to put it - you can create a GitHub issue.

The issue will be reviewed by the Technical Writing team and a Help Wanted label may be added so that community members are able to identify work that they’re able to assist with. If your documentation request/issue applies to a repository other than mattermost/docs, you can ping @justinegeffen or @cwarnermm. Alternatively, you can open an issue in that repo.

Our prioritization process

We understand that all work is important and urgent in some way. However, as a small team, we need to ensure that our coverage is managed tightly.

P1: Urgent and important

  • A page is broken
  • Steps are missing from a critical process
  • An important link is broken
  • An image is broken/not displaying

P2: Important

  • Content is inaccurate; will affect customer goals and productivity
  • Information about new features or changes isn't documented and needs to be

P3: Not urgent/not important

  • Enhancement to the user experience of the docs

Our Board

If urgent and important work is identified, we'll add it to our DWG Board and you can follow its progress there.

i18n contributions

Note: This process is in flight.*

Our product documentation is available for translation contributions. Join the i18n channel on our Community server and connect with our translation community members. The documentation translation process is still being defined, and @cwarnermm is the DRI along with members of the Localization team.

Currently, submitting a translation PR follows the same writing and editing process as other PRs. However, there are additional considerations to bear in mind when submitting your PR as these assist with the approval and merge process:

  1. Do you have an active test instance running with the integrations guide translated so we can validate the rendering and formatting?
  2. If the content you're translating includes screenshots should we keep the original English versions of the screenshots, or consider translated versions of them too?
  3. If the intention is to translate the screenshots, is there a proposed process for keeping them up to date?
  4. Have at least one member of UX team and one member of Apps PM team review the user experience in choosing different languages.
  5. To maintain high standards for translated documentation, set up a process to notify translators when something is changed in the English-version of the docs, and expectation on correcting translations for new releases.
  6. Decide if we want to indicate translations level - e.g. “Alpha” or “Beta” for translations that are in progress.
  7. Test you can successfully rate a translated docs page by selecting a rating emoji. Ping @justine.geffen for validation of this.

Work with the Technical Writing team

What we're doing

The Documentation Working Group (DWG) channel is where you'll find us, and you can view our current projects in the channel's board.

If the card is for documentation related to a release, the documentation needs to be complete at least 10 days prior to release. Please ensure you allow sufficient time for your request to be completed or it will be moved to the next available slot.

Submit an editing request

When submitting a PR for documentation, whether it's a minor update, a new piece of content, or a content proposal, please add the Editor Review label (if possible). Once the Technical Writer/Editor has reviewed the PR they'll remove the label. When all the requested reviews are complete, the Reviews Complete label is applied and the changes are merged.

Providing editorial feedback

If you're asked to provide editorial feedback on a PR, and it's your first editorial feedback request, first read up on the review process here to get an idea of what's expected in terms of turnaround time, type of feedback, and so on.

Editorial feedback is based on the guidelines laid out in the Documentation Style Guide as well as the Voice, Tone, and Writing Style Guide.

Community documentation involvement

Every month the Mattermost community plans, builds, tests, documents, releases, and supports new product improvements for Team Edition to benefit the user community. The Mattermost Enterprise Team does the same for Enterprise Edition to benefit the subscriber community.

A critical part of this development is documentation which ranges from feature documentation to FAQs, guides, and tutorials.

Feature documentation

Feature documentation is a collaborative effort between the Product Manager and Technical Writer within a specific timeframe aligned with releases. Community members are welcome to assist, if the time expectations are manageable.

Feature request documentation is usually located in the mattermost-server repo and the mattermost-webapp repo and are labelled as Docs/Needed. As these are tied to a release (and a deadline) it’s best to only take on the work if you’re sure you can complete it on time. It’s understood that community members contribute in their available time, which is why this type of documentation isn’t usually the best option to take on.

Help Wanted tickets/doc issues

Help Wanted tickets are generally not linked to a release and are more flexible in terms of timeline and delivery date. You can find the documentation Help Wanted tickets here. To start working on one, assign it to yourself, add a comment indicating you’ll be working on it, find the relevant document in the source directory, read through the README file if you're not familiar with the process, and get started.

If you have any questions, you can post them in the Documentation channel and we'll be happy to help.

Engineering/developer documentation

Most, if not all, contributions to the Mattermost project have a documentation impact. As part of the development and submission process, it’s recommended that the relevant documentation be updated (or created) and included in the PR. This provides consistency and accuracy in communicating the changes/new feature and cuts down on having multiple issues and PRs for related documentation.

Visit the Contribute to Documentation page to get started with submitting documentation with your PR. You can read more about the review process here.

GitHub training

GitHub training videos coming soon!