This repository contains the source of the Gantry documentation, currently accessible at http://docs.gantry.org.
The documentation is contained in Pages/ and is structured in folders (chapters), exactly as you see them on the main website. The entirety of the repo found here is intended to act as the user/
folder in a Grav install. This repo contains themes, configuration files, and settings that enable the documentation to be presented in the way they do on the documentation site.
You can read all of the documentation within (as it's just in plain text files) marked up with Markdown.
In order to load a local copy and create working pages, we recommend checking out Grav's documentation as it will give you the information you need to understand the documentation file structure and syntax.
If you would like a local copy of the documentation, you can either download it or you can clone the repository by running the following command:
git clone git://github.com/gantry/docs gantry-docs
Contributing to the documentation is very simple. Feel free to fork the repository, add your changes and give back by issuing a pull request. You can even edit the docs directly on GitHub, without having to ever download the files. Make sure to follow the conventions before issuing a pull request.
You are also very welcome to make any suggestions or report any kind of problem with the documentation by opening a new Issue.
If you decide to fork for providing new content as commits. Please ensure you create a branch for your changes, before making them. This will make the process of integrating them more easier. Every change must pass through the staging
branch first, so please ensure your pull-requests are directed to the proper branch.
To get started with a local environment into the proper staging
branch, you can run these commands:
git clone git://github.com/gantry/docs gantry-docs
cd gantry-docs
git checkout -b develop origin/develop
This is a list of few conventions we follow when writing documentation that help keep the repository well organized and consistent. Feel free to use any other file in the docs as reference. We also have a skeleton with all the conventions in place and with many examples of Markdown in use.
-
Every change/pull request must be applied or requested to the develop branch. Once reviewed, approved and pulled, it will get merged into the master branch and automatically picked up by the website.
-
Folder and file names must be written in snake_case and always lowercase. For example, if you wanted to convert “How to Install” in snake_case, you would name it “how_to_install”. Filenames in the "assets" folders must be instead dash concatenated.
-
There are some reserved names that can’t be used for anything but the scope they are intended for:
-
README.md: [ file ] This is a reserved name of GitHub, used to describe the content of a particular repository directory, like this you are reading right now.
-
chapter.md: [ file ] Chapter files introduce chapters in the documentation. These are top-level markdown files that introduce a collection of pages.
-
docs.md: [ file ] Docs files are individual markdown files that make up the meat and potatoes of documentation. These files explain a particular subject related to Gantry, such as the installation guide or tutorial for creating new particles.
-
REDIRECT.md: [ file ] This file sorely purpose is to redirect projects to different locations. For example, if a project
/docs/project/subproject/
contains aREDIRECT.md
, when hitting on the web thesubproject
page, you’ll get redirect toproject
. By default it takes you back one level, although you can configure where to redirect to through YAML headers (read more about YAML headers below).
-
-
Every header, except for the title one, must be preceded by 2 empty lines and succeeded by no empty line.
-
Headers sub lines (
=
and-
) must always align to the header text. Because this can easily get confusing, be sure to use a mono-spaced fonts. Here a couple of examples of well aligned headers:Header H1 ========= Header H2 ---------
Our Markdown implementation uses special YAML headers. These headers are encapsulated in between a set of three dashes and an empty line. This is how a YAML header looks like:
---
title: Getting Started
taxonomy:
category: docs
tag: [gantry5]
gravui:
enabled: true
tabs: true
callouts: true
process:
twig: true
---
The headers allow for a much flexible output. For example we can define a title of a Markdown file based on its header title variable, rather than the file name itself.
Below is a list of supported YAML
variables that can be used and a description on what they do:
-
title: The title of the article. This is used whenever a page needs to be referenced. When the title is set on a
TOC
file, it globalize the title for each document in the project itself.--- title: Hello World! ---
-
taxonomy: sets the type of article, and its tags. By default, any documentation file should have
category: docs
andtag: [gantry(version)]
settings.The description supports Markdown inline syntax, such as strong, italic, links. You should not be using anything else (ie, headers, images and such).
--- taxonomy: category: docs tag: [gantry5] ---
-
gravui: These settings give you the ability to load specific gravui patterns.
The supported
gravui
settings are listed below:- enabled: Sets whether or not gravui is used at all during page rendering. This is most likely to be
enabled: true
. - tabs: When set to
true
this enables the use of tabs to differentiate between commands that are exclusive to one CMS or another. This defaults tofalse
if the line isn't present. - callouts: When set to
true
, this enables visual callouts to be placed over an image. This is a useful tool when you want to point something out in the image, and provide a tooltip that appears when you move your mouse cursor over it.
- enabled: Sets whether or not gravui is used at all during page rendering. This is most likely to be
-
process: Process tags give you the ability to do things like inject Twig script within the markdown file, and have it execute. This comes in handy when you are doing things like adding classes to images to give them an enhanced appearance. For example,
{.border .shadow}
after a markdown image will apply theborder
andshadow
classes, giving your image a more refined appearance.Here is a more complete example of a line in documentation with Twig:
![Administrator](../../configure/gantry-admin/admin_access_1.png) {.border .shadow}
If you have any questions, feel free to open an Issue.
The RocketTheme Team