FlyByWire Documentation Project
- Documentation Project GitHub
Background
The FlyByWire Documentation Project aims to provide all necessary information and documentation to successfully install and use the FlyByWire A32NX aircraft in Microsoft Flight Simulator.
For this, we provide documentation about the A32NX add-on itself, but also valuable additional documentation on how to fly an airliner on Microsoft Flight Simulator in general and even some specific A320neo documentation for the more involved user.
We apply very high standards to the quality and accuracy of our documentation so that it is easy to read and understand but also as correct as possible. Therefore, we have a strict quality process and everything is reviewed by several users and real pilots from our team.
How to Contribute
Contacts for FlyByWire Documentation Team
If you have questions or suggestions, or if you want to contribute to the FlyByWire Documentation project, please contact us on Discord:
- valastiri
- cdr_maverick
- slein15
Required Tools
To participate in the FlyByWire Documentation Project, you need to have the following tools installed:
- GitHub account and Git (GitHub Quickstart)
- Python (Python Downloads)
- Install the following Python-based tools (see install command below):
- MkDocs (MkDocs)
- mkdocs-awesome-pages-plugin
- mkdocs-git-revision-date-localized-plugin
- mkdocs-redirects
- mkdocs-embed-external-markdown
- mkdocs-video
- mike
- pillow
- cairosvg
-
Install with this single line command:
Run In Terminalpip install -r requirements.txt
Pillow + Cairo Dependency
As part of the new social card feature released with mkdocs-material 8.5.0
Pillow and Cairo Graphics
dependencies were added. We bundle this as part of our requirements.txt
to ensure the dependencies are installed when attempting to test social cards locally. If you encounter any issues with these python packages:
- Install GTK+ for Windows.
For more information, including other operating systems, refer to the Social Card Dependencies Section on the mkdocs-material
documentation.
- Editor / IDE:
- Recommended: Microsoft Visual Studio Code
- recommended plugins to work with Markdown:
- any markdown helper plugin - e.g., https://github.com/yzhang-gh/vscode-markdown
- especially for tables: https://github.com/darkriszty/MarkdownTablePrettify-VSCodeExt
- any plugin to enter Unicode symbols like the narrow non-breakable space for the thousand separator in numbers - e.g., https://github.com/brunnerh/insert-unicode
- recommended plugins to work with Markdown:
- Or any JetBrains IDE, e.g. IntelliJ IDEA or Clion.
- Or any text editor (even Notepad.exe will do) in conjunction with stackedit.io - Create and edit markdown on the web. Useful if you don't have / can't set up MkDocs locally on your machine. Does not support material references. Please note this in your PR, so a maintainer can double-check your references render appropriately.
- Recommended: Microsoft Visual Studio Code
Social Cards Feature
Important Information
For general purposes, you do not need to test or utilize this feature locally unless you want to develop or change configurations related to this feature. Please be aware of the information below if you intend to test this locally.
We have added the social cards feature to the FBW documentation project. When generating the social cards locally, the directory .cache
is created where all the assets are generated. See Complete Local Builds.
You may need to manually clean any files within the .cache
directory if you encounter any build issues after generating / modifying configuration files related to this
feature.
Process
Preview your Local Clone
- Fork the - Documentation Project GitHub (How to fork a repository).
- Create a local clone (How to clone your forked repository).
- Checkout the "primary" branch - this is the main branch of the current FlyByWire Documentation Project.
-
In a command line terminal, go to the cloned repository folder and start
mkdocs.exe serve
to start the local preview server.This should look like this:
> mkdocs.exe serve INFO - Building documentation... INFO - Cleaning site directory INFO - Documentation built in 4.03 seconds INFO - [12:05:30] Serving on http://127.0.0.1:8000/
Building the Project with No Internet Connection
This project utilizes the
external-markdown
plugin, which pulls MarkDown files from other repositories during the build for both production and development. This helps reference other important documentation externally without having to copy and paste it into this project.When working on a feature branch without an internet connection, your development server may exit and fail to build, resulting in:
Error! https://[hyperlink here] returned connection error
To bypass this issue, you can comment out the
external-markdown
plugin temporarily inmkdocs.yml
found in the /root of this project. (Please ensure not to commit this change when creating a Pull Request.) See the example below:mkdocs.yml example configured for offline builds# Plugins plugins: search: lang: en # Comment out the plugin below if building docs without an internet connection. # external-markdown: {}
Faster Preview Server
You can opt to use a faster instance of the developer server by invoking the flag --dirtyreload
. This just checks for any markdown that has changed since the HTML was rendered and will reconstruct any relevant pages only, rather than rebuilding the entire website.
mkdocs.exe serve --dirty
Navigation and new internal links may not get updated on other pages while using --dirty
. Verify links using the standard serve or build command.
- You can now browse the current checked out branch in a browser at this address: http://127.0.0.1:8000/. The site renders every time you save any
filename.md
you are working on. -
Optional: Build a static site locally for testing:
mkdocs build --clean --no-directory-urls
- The site will be built locally under
/site
on in your local repo for user testing. Openindex.html
in the root of/site
to preview. - Note:
--no-directory-urls
allows usage of reference links when browsing the locally built site. Prevents having to find each index.html related to everyfilename.md
to preview the relevant page.
- The site will be built locally under
Make Changes or Additions to the Documentation
- Create a new branch based on branch "primary" (might differ for certain subprojects) and checkout this new branch. Give a short but meaningful name to the branch.
- Make initial changes to your local branch.
- Create a Draft Pull Request (aka PR) early to let people know what you are working on.
- Explain in the PR Description what you are changing/adding and how people should review your changes.
- Work on your changes locally, preview constantly and push your changes regularly to get a preview deployment for others to provide feedback.
- Every time you push changes to your PR, a preview is generated with a URL. You can share this link in Discord for the team to provide feedback easily. The URL (by the Vercel bot) is visible as a comment on your PR GitHub page.
- When finished, push your final changes to the PR, update the PR description if required and mark it "Ready for Review".
- Someone from the documentation team will review your changes, provide feedback, potentially ask for changes, and eventually approve and merge your changes.
Adding Plugins or Markdown Extensions
Please use the alternative "key/value" pairs method when adding plugins or markdown extensions, with special note that an empty value must be provided when no options are defined.
plugins:
search: {}
awesome-pages: {}
plugins:
- search
- awesome-pages
Build Pipeline and Config Changes
To facilitate smooth local development, we have made some changes between production builds and local development.
Building for production now uses the production.yml
file, which deep merges with mkdocs.yml using the INHERIT
function with MkDocs.
mkdocs build --config-file production.yml
Complete Local Builds
You can still follow the instructions to preview your local clone to test and preview your changes locally.
If you would like to fully test a complete build of the production website, you need to run the following:
mkdocs.exe serve --config-file production.yml
mkdocs.exe build --clean --no-directory-urls --config-file production.yml
Additional Plugins in production.yml
The following plugins are included:
- Social Cards
How to Write Documentation for FlyByWire
Technical How-To
- You can edit existing pages simply by editing an existing
pagename.md
. - To create a page, simply create a new file "pagename.md" in an appropriate folder and start writing your documentation. Best practices it to look at other pages regarding the general structure (Headings, Material for MkDocs features, etc.).
- Create the page in the navigation folder you feel this page belongs to. The Documentation Team will be happy to support you with the best location and also how to create a navigation to your page.
- During the PR Review, the page can still be moved and navigation can be changed/added. So don't worry too much about it and focus on the content for your page.
- Add images to the section's asset folder. Consider creating a folder for your page when using several images.
- Although the FlyByWire Documentation Team will take care of navigation, it might still be of interest how the navigation is done. This is well explained on the mkdocs-awesome-pages-plugin's README on their GitHub
Embedding YouTube Videos
We have included the plugin mkdocs-video
to streamline adding YouTube embeds into documentation. This removes the necessity to inline <iframe>
information within documentation pages.
The plugin uses the markdown image syntax with a custom marker defined in mkdocs.yml: video-embed
.
![video-embed](https://www.youtube.com/embed/3i1FaGKOwII)
Search Exclusion
While writing documentation, you may want to include pages in the final build as part of the docs/
directory, but not have these pages referenced within the search index.
You can simply add to the top of the document the following meta information to utilize mkdocs-material's built in search exclusion:
---
search:
exclude: true
---
Tips to Work Effectively with mkdocs
(Change, Previews, etc.)
- Have your editor and browser preview side-by-side on your screen.
- Every time you save your file, the "mkdocs serve" should make your browser reload, and you can preview your changes directly.
- Start with the structure of your documentation page. E.g., headlines first and maybe notes below the headlines of what the section should cover. Build up your page from there.
- How to do:
- Links:
[Link-Text](https://www.target.domain/page)
- internal links need a relative path to the .md file
- add
{target=new}
to external links - look into existing pages for examples
- Other Material for MkDocs features
- Links:
Writing Good Documentation
- Write documentation professionally and clearly.
- Write for the targeted audience (Sim Beginner, Sim Veteran, Developers, etc.) and don't assume too much pre-knowledge on the reader's side.
- Use the full availability of features baked into Material for MkDocs to create readable and well formatted guides.
- Add illustrations where appropriate. Make sure you optimize images to be as small as possible (resize to their actually used size and use JPG Compression (50% is mostly ok)). See Image Assets Process for more information.
- Ensure relevant filenames are web-friendly slugs.
- Don't hesitate to get feedback from the FlyByWire Documentation Team early and often.
- Proofread your work carefully before marking "Ready for Review".
Image Assets Process
- Create the image (e.g. screenshots)
- Edit the image (e.g. add comments, lines, boxes, arrows, etc.)
- If you think the original is worth it store it in
/src/assets
- but most images aren't worth it as screenshots are quickly retaken (Keeping a local copy of all your screenshots is good practice just in case - but it is not worth to clutter the repo with them) - Put the edited image in the folder for the topic - e.g.
\docs\pilots-corner\assets\advanced-guides\vnav
for images related to the VNAV topic -
Link the image in the markdown document - decide on the size you need (See admonition below for references)
Width of images on docs based on the responsive layout.
Size Width 100% 826 px 95% 785 px 90% 743 px 85% 702 px 80% 661 px 75% 620 px 70% 578 px 65% 537 px 60% 496 px 55% 454 px 50% 413 px 45% 372 px 40% 330 px 35% 289 px 30% 248 px 25% 206 px 20% 165 px 15% 124 px 10% 83 px 5% 41 px -
Change the size according to the table - max width is 826 px
- Compress the png image with a tool - Website Planet Image Compressor
- Make sure size and quality are good - usually < 100 kB
Style
- Use the units of measurement and their abbreviations as used by ICAO Annex 5. This document can be downloaded, for example, on the website of the Swiss Federal Office of Civil Aviation.
- If the current de facto measurement unit differs from the recommended one or different units are used in some regions, use the most widespread unit and add the recommended or regional one(s) in brackets.
- Regarding typography of numbers and units, the ISO Conventions summarized in this checklist should be followed, e.g., addition of a non-breaking space (Unicode 160) between the number and the unit, except for degree, minute of arc, and second of arc, and the use of a thin or narrow non-breaking space (Unicode 8239) as a thousand seperator, as well as between the number and the sign (+, - etc.).
Ideas and Issues
Please use GitHub's Issue tracker for any documentation request or issues you might have encountered.