2016-02-09 21:59:37 +01:00
# Getting started
## Installation
### Installing MkDocs
2017-11-05 14:40:30 +01:00
Before installing [MkDocs][1], you need to make sure you have Python and `pip`
2016-12-29 17:55:08 +01:00
– the Python package manager – up and running. You can verify if you're already
2016-02-24 17:31:01 +01:00
good to go with the following commands:
2016-02-09 21:59:37 +01:00
``` sh
python --version
2019-11-30 01:45:15 +09:00
# Python 3.8.0
2016-02-09 21:59:37 +01:00
pip --version
2019-11-30 01:45:15 +09:00
# pip 19.3.1
2016-02-09 21:59:37 +01:00
```
Installing and verifying MkDocs is as simple as:
``` sh
pip install mkdocs & & mkdocs --version
2019-11-30 01:45:15 +09:00
# mkdocs, version 1.0.4
2016-02-09 21:59:37 +01:00
```
2019-11-30 01:45:15 +09:00
Material requires MkDocs >= 1.0.0.
2016-12-29 17:55:08 +01:00
2018-06-10 14:30:26 +01:00
[1]: https://www.mkdocs.org
2016-12-29 17:55:08 +01:00
2016-02-09 21:59:37 +01:00
### Installing Material
2017-01-14 13:43:19 +01:00
#### using pip
2016-12-29 17:55:08 +01:00
Material can be installed with `pip` :
2016-02-09 21:59:37 +01:00
``` sh
pip install mkdocs-material
```
2017-01-14 13:43:19 +01:00
#### using choco
2017-11-05 14:40:30 +01:00
If you're on Windows you can use [Chocolatey][2] to install [Material][3]:
2017-01-14 13:43:19 +01:00
``` dos
choco install mkdocs-material
```
2017-11-05 14:40:30 +01:00
This will install all required dependencies like [Python][4] and [MkDocs][5].
2017-01-14 13:43:19 +01:00
2017-11-05 14:40:30 +01:00
[2]: https://chocolatey.org
[3]: https://chocolatey.org/packages/mkdocs-material
[4]: https://chocolatey.org/packages/python
[5]: https://chocolatey.org/packages/mkdocs
2017-01-14 13:43:19 +01:00
#### cloning from GitHub
2016-12-29 17:55:08 +01:00
2017-01-12 20:15:30 +01:00
Material can also be used without a system-wide installation by cloning the
2016-12-29 17:55:08 +01:00
repository into a subfolder of your project's root directory:
2016-02-09 21:59:37 +01:00
``` sh
2016-12-29 17:55:08 +01:00
git clone https://github.com/squidfunk/mkdocs-material.git
2016-02-09 21:59:37 +01:00
```
2017-11-05 14:40:30 +01:00
This is especially useful if you want to [extend the theme][6] and
[override some parts][7] of the theme. The theme will reside in the folder
2017-01-07 20:07:41 +01:00
`mkdocs-material/material` .
2016-12-29 17:55:08 +01:00
2017-11-05 14:40:30 +01:00
[6]: customization.md#extending -the-theme
[7]: customization.md#overriding -partials
2017-06-21 10:25:00 +02:00
2017-03-11 18:01:14 +01:00
### Troubleshooting
!!! warning "Installation on macOS"
When you're running the pre-installed version of Python on macOS, `pip`
tries to install packages in a folder for which your user might not have
2017-03-11 18:36:34 +01:00
the adequate permissions. There are two possible solutions for this:
2017-03-11 18:01:14 +01:00
1. **Installing in user space** (recommended): Provide the `--user` flag
to the install command and `pip` will install the package in a user-site
location. This is the recommended way.
2. **Switching to a homebrewed Python** : Upgrade your Python installation
to a self-contained solution by installing Python with Homebrew. This
should eliminate a lot of problems you may be having with `pip` .
!!! failure "Error: unrecognized theme 'material'"
2017-03-11 18:36:34 +01:00
If you run into this error, the most common reason is that you installed
2017-03-11 18:01:14 +01:00
MkDocs through some package manager (e.g. Homebrew or `apt-get` ) and the
Material theme through `pip` , so both packages end up in different
2017-08-29 13:17:26 +07:00
locations. MkDocs only checks its install location for themes.
2017-03-11 18:01:14 +01:00
2017-11-05 14:40:30 +01:00
### Alternative: Using Docker
If you're familiar with Docker, the official [Docker image][8] for Material
comes with all dependencies pre-installed and ready-to-use with the latest
version published on PyPI, packaged in a very small image. Pull it with:
```
docker pull squidfunk/mkdocs-material
```
The `mkdocs` executable is provided as an entrypoint, `serve` is the default
command. Start the development server in your project root with:
```
2018-01-13 17:19:07 +01:00
docker run --rm -it -p 8000:8000 -v ${PWD}:/docs squidfunk/mkdocs-material
2017-11-05 14:40:30 +01:00
```
2018-01-13 17:19:07 +01:00
If you're using Windows command prompt (`cmd.exe` ), substitute `${PWD}` with
`"%cd%"` .
2017-11-05 14:40:30 +01:00
[8]: https://hub.docker.com/r/squidfunk/mkdocs-material/
2016-12-29 17:55:08 +01:00
## Usage
2017-06-21 10:25:00 +02:00
In order to enable the theme just add one of the following lines to your
2018-01-18 21:19:10 +01:00
project's `mkdocs.yml` . If you installed Material using a package manager:
2016-02-09 21:59:37 +01:00
``` yaml
2017-10-31 19:42:43 +01:00
theme:
name: 'material'
2016-02-09 21:59:37 +01:00
```
2017-01-12 20:15:30 +01:00
If you cloned Material from GitHub:
2016-02-09 21:59:37 +01:00
``` yaml
2017-10-31 19:42:43 +01:00
theme:
name: null
custom_dir: 'mkdocs-material/material'
2016-02-09 21:59:37 +01:00
```
2017-03-11 18:36:34 +01:00
MkDocs includes a development server, so you can review your changes as you go.
2017-01-12 20:15:30 +01:00
The development server can be started with the following command:
2016-02-09 21:59:37 +01:00
``` sh
mkdocs serve
```
2017-06-21 10:25:00 +02:00
Now you can point your browser to [http://localhost:8000][9] and the Material
theme should be visible. From here on, you can start writing your documentation,
2017-10-31 19:42:43 +01:00
or read on and customize the theme.
2017-01-07 20:07:41 +01:00
2017-01-14 12:42:53 +01:00
[9]: http://localhost:8000
2016-02-09 21:59:37 +01:00
2017-10-31 19:42:43 +01:00
## Configuration
2016-02-09 21:59:37 +01:00
2017-10-31 19:42:43 +01:00
### Color palette
2016-02-24 17:31:01 +01:00
2017-10-13 09:32:28 -04:00
A default hue is defined for every primary and accent color on Google's
2017-06-21 10:25:00 +02:00
Material Design [color palette][10], which makes it very easy to change the
2016-12-29 17:55:08 +01:00
overall look of the theme. Just set the primary and accent colors using the
2017-06-21 10:25:00 +02:00
following variables:
2016-02-24 17:31:01 +01:00
``` yaml
2017-10-31 19:42:43 +01:00
theme:
2016-02-24 17:31:01 +01:00
palette:
primary: 'indigo'
2017-11-05 14:26:44 +01:00
accent: 'indigo'
2016-02-24 17:31:01 +01:00
```
2017-01-12 20:15:30 +01:00
Color names are case-insensitive, but must match the names of the Material
Design color palette. Valid values are: `red` , `pink` , `purple` , `deep purple` ,
`indigo` , `blue` , `light blue` , `cyan` , `teal` , `green` , `light green` , `lime` ,
2017-11-19 17:41:06 +01:00
`yellow` , `amber` , `orange` , `deep orange` , `brown` , `grey` , `blue grey` and
2017-12-09 12:13:01 -05:00
`white` . The last four colors can only be used as a primary color.
2016-12-29 17:55:08 +01:00
If the color is set via this configuration, an additional CSS file that
2017-06-21 10:25:00 +02:00
defines the color palette is automatically included. If you want to keep things
lean, clone the repository and recompile the theme with your custom colors set.
See the guide on [customization][11] for more information.
2016-12-29 17:55:08 +01:00
2017-01-14 12:42:53 +01:00
[10]: http://www.materialui.co/colors
[11]: customization.md
2016-12-29 17:55:08 +01:00
#### Primary colors
2017-11-01 14:01:23 +01:00
> Default: `indigo`
2016-12-29 17:55:08 +01:00
Click on a tile to change the primary color of the theme:
< button data-md-color-primary = "red" > Red< / button >
< button data-md-color-primary = "pink" > Pink< / button >
< button data-md-color-primary = "purple" > Purple< / button >
< button data-md-color-primary = "deep-purple" > Deep Purple< / button >
< button data-md-color-primary = "indigo" > Indigo< / button >
< button data-md-color-primary = "blue" > Blue< / button >
< button data-md-color-primary = "light-blue" > Light Blue< / button >
< button data-md-color-primary = "cyan" > Cyan< / button >
< button data-md-color-primary = "teal" > Teal< / button >
< button data-md-color-primary = "green" > Green< / button >
< button data-md-color-primary = "light-green" > Light Green< / button >
< button data-md-color-primary = "lime" > Lime< / button >
< button data-md-color-primary = "yellow" > Yellow< / button >
< button data-md-color-primary = "amber" > Amber< / button >
< button data-md-color-primary = "orange" > Orange< / button >
< button data-md-color-primary = "deep-orange" > Deep Orange< / button >
< button data-md-color-primary = "brown" > Brown< / button >
< button data-md-color-primary = "grey" > Grey< / button >
< button data-md-color-primary = "blue-grey" > Blue Grey< / button >
2019-08-22 16:11:51 +02:00
< button data-md-color-primary = "black" > Black< / button >
2017-11-19 17:41:06 +01:00
< button data-md-color-primary = "white" > White< / button >
2016-12-29 17:55:08 +01:00
< script >
var buttons = document.querySelectorAll("button[data-md-color-primary]");
Array.prototype.forEach.call(buttons, function(button) {
button.addEventListener("click", function() {
document.body.dataset.mdColorPrimary = this.dataset.mdColorPrimary;
})
})
< / script >
#### Accent colors
2017-11-01 14:01:23 +01:00
> Default: `indigo`
2016-12-29 17:55:08 +01:00
Click on a tile to change the accent color of the theme:
< button data-md-color-accent = "red" > Red< / button >
< button data-md-color-accent = "pink" > Pink< / button >
< button data-md-color-accent = "purple" > Purple< / button >
< button data-md-color-accent = "deep-purple" > Deep Purple< / button >
< button data-md-color-accent = "indigo" > Indigo< / button >
< button data-md-color-accent = "blue" > Blue< / button >
< button data-md-color-accent = "light-blue" > Light Blue< / button >
< button data-md-color-accent = "cyan" > Cyan< / button >
< button data-md-color-accent = "teal" > Teal< / button >
< button data-md-color-accent = "green" > Green< / button >
< button data-md-color-accent = "light-green" > Light Green< / button >
< button data-md-color-accent = "lime" > Lime< / button >
< button data-md-color-accent = "yellow" > Yellow< / button >
< button data-md-color-accent = "amber" > Amber< / button >
< button data-md-color-accent = "orange" > Orange< / button >
< button data-md-color-accent = "deep-orange" > Deep Orange< / button >
< script >
var buttons = document.querySelectorAll("button[data-md-color-accent]");
Array.prototype.forEach.call(buttons, function(button) {
button.addEventListener("click", function() {
document.body.dataset.mdColorAccent = this.dataset.mdColorAccent;
})
})
< / script >
2016-02-24 17:31:01 +01:00
2017-10-31 19:42:43 +01:00
### Font family
2016-02-09 21:59:37 +01:00
2017-11-01 14:01:23 +01:00
> Default: `Roboto` and `Roboto Mono`
2017-06-21 10:25:00 +02:00
By default the [Roboto font family][12] is included with the theme, specifically
the regular sans-serif type for text and the `monospaced` type for code. Both
fonts are loaded from [Google Fonts][13] and can be changed to other fonts,
like for example the [Ubuntu font family][14]:
2016-02-09 21:59:37 +01:00
``` yaml
2017-10-31 19:42:43 +01:00
theme:
2016-02-17 18:08:11 +01:00
font:
2016-12-29 17:55:08 +01:00
text: 'Ubuntu'
code: 'Ubuntu Mono'
2016-02-17 18:08:11 +01:00
```
2017-06-21 10:25:00 +02:00
The text font will be loaded in weights 400 and **700** , the `monospaced` font
in regular weight. If you want to load fonts from other destinations or don't
want to use the Google Fonts loading magic, just set `font` to `false` :
2016-02-17 18:08:11 +01:00
``` yaml
2017-10-31 19:42:43 +01:00
theme:
2017-03-11 18:36:34 +01:00
font: false
2016-02-09 21:59:37 +01:00
```
2017-01-14 12:42:53 +01:00
[12]: https://fonts.google.com/specimen/Roboto
2017-02-24 22:53:12 +01:00
[13]: https://fonts.google.com
2017-01-14 12:42:53 +01:00
[14]: https://fonts.google.com/specimen/Ubuntu
2016-12-29 17:55:08 +01:00
2017-10-31 19:42:43 +01:00
### Logo
2017-11-01 14:01:23 +01:00
> Default icon: `school`
2017-10-31 19:42:43 +01:00
Your logo should have rectangular shape with a minimum resolution of 128x128,
leave some room towards the edges and be composed of high contrast areas on a
transparent ground, as it will be placed on the colored header bar and drawer.
Simply create the folder `docs/images` , add your logo and embed it with:
``` yaml
theme:
logo: 'images/logo.svg'
```
Additionally, the default icon can be changed by setting an arbitrary ligature
(or Unicode code point) from the [Material Design icon font][15], e.g.
``` yaml
theme:
logo:
icon: 'cloud'
```
[15]: https://material.io/icons/
### Language
2018-03-21 20:26:53 +01:00
!!! info "Call for Contributions: Add languages/translations to Material"
Help translate Material into more languages - it's just **one click** and
2019-12-11 17:17:54 +01:00
takes approximately **2 minutes** : [click here ](https://github.com/squidfunk/mkdocs-material/issues/new?template=translate.md )
2018-03-21 20:26:53 +01:00
2017-10-31 19:42:43 +01:00
#### Localization
2017-11-01 14:01:23 +01:00
> Default: `en`
2017-10-31 19:42:43 +01:00
Material for MkDocs supports internationalization (i18n) and provides
2018-01-31 17:56:26 +01:00
translations for all template variables and labels in the following languages:
< table style = "white-space: nowrap;" >
< thead >
< tr >
2019-12-18 16:07:01 +09:00
< th colspan = "4" > Available languages< / th >
2018-01-31 17:56:26 +01:00
< / tr >
< / thead >
< tbody >
< tr >
2019-08-27 17:41:51 +02:00
< td > < code > af< / code > / Afrikaans< / td >
2018-02-12 21:36:01 +01:00
< td > < code > ar< / code > / Arabic< / td >
2018-02-21 23:08:20 +01:00
< td > < code > ca< / code > / Catalan< / td >
2018-06-29 11:14:23 +02:00
< td > < code > cs< / code > / Czech< / td >
2018-01-31 17:56:26 +01:00
< / tr >
< tr >
2019-08-27 17:41:51 +02:00
< td > < code > da< / code > / Danish< / td >
2018-06-29 11:14:23 +02:00
< td > < code > nl< / code > / Dutch< / td >
2018-02-21 23:08:20 +01:00
< td > < code > en< / code > / English< / td >
2019-10-03 12:14:32 +03:00
< td > < code > et< / code > / Estonian< / td >
2018-01-31 17:56:26 +01:00
< / tr >
< tr >
2019-10-03 12:14:32 +03:00
< td > < code > fi< / code > / Finnish< / td >
2019-08-27 17:41:51 +02:00
< td > < code > fr< / code > / French< / td >
2018-06-29 11:14:23 +02:00
< td > < code > gl< / code > / Galician< / td >
2018-04-26 10:38:26 +02:00
< td > < code > de< / code > / German< / td >
2018-01-31 17:56:26 +01:00
< / tr >
< tr >
2019-10-03 12:14:32 +03:00
< td > < code > gr< / code > / Greek< / td >
2019-08-27 17:41:51 +02:00
< td > < code > he< / code > / Hebrew< / td >
2019-02-13 15:59:56 +01:00
< td > < code > hi< / code > / Hindi< / td >
2018-10-23 09:04:26 +02:00
< td > < code > hr< / code > / Croatian< / td >
2018-01-31 17:56:26 +01:00
< / tr >
< tr >
2019-10-03 12:14:32 +03:00
< td > < code > hu< / code > / Hungarian< / td >
2019-08-27 17:41:51 +02:00
< td > < code > id< / code > / Indonesian< / td >
2019-02-13 15:59:56 +01:00
< td > < code > it< / code > / Italian< / td >
2018-10-23 09:04:26 +02:00
< td > < code > ja< / code > / Japanese< / td >
2018-02-12 21:36:01 +01:00
< / tr >
< tr >
2019-10-03 12:14:32 +03:00
< td > < code > kr< / code > / Korean< / td >
2019-08-27 17:41:51 +02:00
< td > < code > no< / code > / Norwegian< / td >
2019-04-28 11:37:56 +02:00
< td colspan = "2" > < code > nn< / code > / Norwegian (Nynorsk)< / td >
2018-08-04 20:35:14 +02:00
< / tr >
< tr >
2019-10-03 12:14:32 +03:00
< td > < code > fa< / code > / Persian< / td >
2019-08-27 17:41:51 +02:00
< td > < code > pl< / code > / Polish< / td >
2019-04-28 11:37:56 +02:00
< td > < code > pt< / code > / Portugese< / td >
2020-02-10 12:34:58 +01:00
< td > < code > ro< / code > / Romanian< / td >
2019-02-13 15:59:56 +01:00
< / tr >
< tr >
2020-02-10 12:34:58 +01:00
< td > < code > ru< / code > / Russian< / td >
2019-10-03 12:14:32 +03:00
< td > < code > sr< / code > / Serbian< / td >
2019-08-27 17:41:51 +02:00
< td > < code > sh< / code > / Serbo-Croatian< / td >
2019-04-28 11:37:56 +02:00
< td > < code > sk< / code > / Slovak< / td >
2018-03-21 20:14:29 +01:00
< / tr >
< tr >
2020-02-10 12:34:58 +01:00
< td > < code > si< / code > / Slovenian< / td >
2019-10-03 12:14:32 +03:00
< td > < code > es< / code > / Spanish< / td >
2019-08-27 17:41:51 +02:00
< td > < code > sv< / code > / Swedish< / td >
2019-12-02 15:50:04 +01:00
< td > < code > th< / code > / Thai< / td >
2019-04-28 11:37:56 +02:00
< / tr >
2020-02-10 12:34:58 +01:00
< td > < code > tr< / code > / Turkish< / td >
2019-12-02 15:50:04 +01:00
< td > < code > uk< / code > / Ukrainian< / td >
2020-02-10 12:34:58 +01:00
< td colspan = "2" > < code > vi< / code > / Vietnamese< / td >
2019-10-03 12:14:32 +03:00
< tr >
2018-03-21 20:14:29 +01:00
< / tr >
< tr >
2020-02-10 12:34:58 +01:00
< td colspan = "2" > < code > zh< / code > / Chinese (Simplified)< / td >
2019-10-03 12:14:32 +03:00
< td colspan = "2" > < code > zh-Hant< / code > / Chinese (Traditional)< / td >
< / tr >
< tr >
2020-02-10 12:34:58 +01:00
< td colspan = "2" > < code > zh-TW< / code > / Chinese (Taiwanese)< / td >
< td colspan = "2" align = "right" >
2019-12-11 17:17:54 +01:00
< a href = "https://github.com/squidfunk/mkdocs-material/issues/new?template=translate.md" > Submit a new language< / a >
2018-01-31 17:56:26 +01:00
< / td >
< / tr >
< / tbody >
< / table >
Specify the language with:
2017-10-31 19:42:43 +01:00
``` yaml
theme:
language: 'en'
```
If the language is not specified, Material falls back to English. To create a
translation for another language, copy the localization file of an existing
language, name the new file using the [2-letter language code][16] and adjust
all translations:
``` sh
cp partials/language/en.html partials/language/jp.html
```
2017-11-05 14:54:00 +01:00
[16]: https://www.w3schools.com/tags/ref_language_codes.asp
2017-10-31 19:42:43 +01:00
2018-01-13 17:19:07 +01:00
#### Text direction
2018-02-01 23:47:00 +01:00
> Default: best match for given theme language, automatically set
2018-01-13 17:19:07 +01:00
Material supports both, left-to-right (`ltr` ) and right-to-left (`rtl` ) text
direction. This enables more languages like Arabic, Hebrew, Syriac and others
to be used with the theme:
2018-01-18 21:19:10 +01:00
``` yaml
2018-01-13 17:19:07 +01:00
theme:
2018-01-18 21:19:10 +01:00
direction: 'rtl'
2018-01-13 17:19:07 +01:00
```
2017-10-31 19:42:43 +01:00
#### Site search
2018-01-21 22:56:54 +01:00
> Default: best match for given theme language, automatically set
2017-11-01 14:01:23 +01:00
2017-10-31 19:42:43 +01:00
Site search is implemented using [lunr.js][17], which includes stemmers for the
English language by default, while stemmers for other languages are included
2018-01-21 22:56:54 +01:00
with [lunr-languages][18], both of which are integrated with this theme.
Material selects the matching (or best-matching) stemmer for the given theme
language. Multilingual search can be activated in your project's `mkdocs.yml`
by explicitly defining the search language(s):
2017-10-31 19:42:43 +01:00
``` yaml
extra:
search:
2017-11-05 16:00:24 +01:00
language: 'en, de, ru'
2017-10-31 19:42:43 +01:00
```
2018-01-31 17:56:26 +01:00
At the time of writing, the following languages are supported:
< table style = "white-space: nowrap;" >
< thead >
< tr >
2019-12-18 16:07:01 +09:00
< th colspan = "4" > Available language stemmers< / th >
2018-01-31 17:56:26 +01:00
< / tr >
< / thead >
< tbody >
< tr >
< td > < code > da< / code > / Danish< / td >
< td > < code > du< / code > / Dutch< / td >
< td > < code > en< / code > / English< / td >
< td > < code > fi< / code > / Finnish< / td >
< / tr >
< tr >
< td > < code > fr< / code > / French< / td >
< td > < code > de< / code > / German< / td >
< td > < code > hu< / code > / Hungarian< / td >
< td > < code > it< / code > / Italian< / td >
< / tr >
< tr >
2019-03-12 16:33:58 +01:00
< td > < code > ja< / code > / Japanese< / td >
2018-01-31 17:56:26 +01:00
< td > < code > no< / code > / Norwegian< / td >
< td > < code > pt< / code > / Portugese< / td >
< td > < code > ro< / code > / Romanian< / td >
< / tr >
< tr >
< td > < code > ru< / code > / Russian< / td >
< td > < code > es< / code > / Spanish< / td >
< td > < code > sv< / code > / Swedish< / td >
< td > < code > tr< / code > / Turkish< / td >
< / tr >
< / tbody >
< / table >
2017-10-31 19:42:43 +01:00
2018-08-05 18:38:16 +02:00
!!! warning "MkDocs 1.0 compatibility"
2017-12-02 14:56:06 +01:00
2018-08-05 18:38:16 +02:00
While MkDocs 1.0 supports prebuilding the search index, Material currently
doesn't support this setting as the default search behavior of the original
theme was heavily modified for the sake of a better UX. Integration is
possible, but a small subset of the features Material provides will not be
portable to the prebuilt index mainly due to missing localization.
2017-12-02 14:56:06 +01:00
2017-10-31 19:42:43 +01:00
!!! warning "Only specify the languages you really need"
Be aware that including support for other languages increases the general
JavaScript payload by around 20kb (without gzip) and by another 15-30kb per
language.
The separator for tokenization can be customized which makes it possible
to index parts of words that are separated by `-` or `.` :
``` yaml
extra:
search:
tokenizer: '[\s\-\.]+'
```
[17]: https://lunrjs.com
[18]: https://github.com/MihaiValentin/lunr-languages
2017-11-01 12:04:22 +01:00
### Favicon
2017-11-01 14:01:23 +01:00
> Default: `assets/images/favicon.png`
2017-11-01 12:04:22 +01:00
The default favicon can be changed by setting the `favicon` variable to an
`.ico` or image file:
``` yaml
theme:
2017-12-06 15:18:53 -05:00
favicon: 'assets/images/favicon.ico'
2017-11-01 12:04:22 +01:00
```
2017-10-31 19:42:43 +01:00
### Features
#### Tabs
2017-11-01 14:01:23 +01:00
> Default: `false`
2019-02-09 17:33:08 +01:00
By default, the entire navigation is rendered on the left side using collapsible
sections (different from the default MkDocs theme which renders the top-level
sections in the header), because horizontal navigation is often problematic on
smaller screens. However, for large documentation projects it's sometimes
desirable to add another navigation layer to separate top-level sections.
Material achieves this with the tabs feature, which can be enabled by setting
the respective feature flag to `true` :
2017-10-31 19:42:43 +01:00
``` yaml
theme:
feature:
tabs: true
```
2019-02-09 17:33:08 +01:00
When tabs are enabled, *top-level sections* will be rendered in an additional
layer directly below the header. The navigation on the left side will only
include the pages contained within the selected section. Furthermore, *top-level
pages* defined inside your project's `mkdocs.yml` will be grouped under the
first tab which will receive the title of the first page.
2017-10-31 19:42:43 +01:00
## Customization
2017-03-11 17:24:03 +01:00
### Adding a source repository
To include a link to the repository of your project within your documentation,
set the following variables via your project's `mkdocs.yml` :
``` yaml
2017-11-05 14:26:44 +01:00
repo_name: 'squidfunk/mkdocs-material'
repo_url: 'https://github.com/squidfunk/mkdocs-material'
2017-03-11 17:24:03 +01:00
```
2017-06-21 10:25:00 +02:00
The name of the repository will be rendered next to the search bar on big
screens and as part of the main navigation drawer on smaller screen sizes.
2017-03-11 17:24:03 +01:00
Furthermore, if `repo_url` points to a GitHub, BitBucket or GitLab repository,
2017-03-11 18:36:34 +01:00
the respective service logo will be shown next to the name of the repository.
2017-03-11 17:24:03 +01:00
Additionally, for GitHub, the number of stars and forks is shown.
2017-08-02 14:09:13 +02:00
If the repository is hosted in a private environment, the service logo can be
set explicitly by setting `extra.repo_icon` to `github` , `gitlab` or
`bitbucket` .
2017-10-13 09:32:28 -04:00
!!! question "Why is there an edit button at the top of every article?"
2017-03-11 17:24:03 +01:00
If the `repo_url` is set to a GitHub or BitBucket repository, and the
2017-03-11 18:36:34 +01:00
`repo_name` is set to *GitHub* or *BitBucket* (implied by default), an
2017-03-11 17:24:03 +01:00
edit button will appear at the top of every article. This is the automatic
2017-10-31 19:42:43 +01:00
behavior that MkDocs implements. See the [MkDocs documentation][19] on more
2017-03-11 17:24:03 +01:00
guidance regarding the `edit_uri` attribute, which defines whether the edit
2017-04-29 00:04:00 +09:00
button is shown or not.
2017-03-11 17:24:03 +01:00
2018-06-10 14:30:26 +01:00
[19]: https://www.mkdocs.org/user-guide/configuration/#edit_uri
2017-09-01 20:23:44 +07:00
2016-12-29 17:55:08 +01:00
### Adding social links
2016-02-09 21:59:37 +01:00
2017-06-21 10:25:00 +02:00
Social accounts can be linked in the footer of the documentation using the
2017-10-31 19:42:43 +01:00
automatically included [FontAwesome][20] webfont. The `type` must denote the
2017-06-21 10:25:00 +02:00
name of the social service, e.g. `github` , `twitter` or `linkedin` and the
`link` must contain the URL you want to link to:
2016-02-09 21:59:37 +01:00
``` yaml
extra:
2016-12-29 17:55:08 +01:00
social:
- type: 'github'
link: 'https://github.com/squidfunk'
- type: 'twitter'
link: 'https://twitter.com/squidfunk'
- type: 'linkedin'
2019-12-18 16:32:21 +09:00
link: 'https://www.linkedin.com/in/squidfunk'
2016-02-09 21:59:37 +01:00
```
2017-01-12 20:15:30 +01:00
The links are generated in order and the `type` of the links must match the
name of the FontAwesome glyph. The `fa` is automatically added, so `github`
will result in `fa fa-github` .
2016-12-29 17:55:08 +01:00
2019-12-18 16:32:21 +09:00
[20]: https://fontawesome.com/v4.7.0/icons/
2017-10-31 19:42:43 +01:00
2018-11-17 17:57:47 +01:00
### Adding a Web App Manifest
2017-10-31 19:42:43 +01:00
2018-11-17 17:57:47 +01:00
A [Web App Manifest][21] is a simple JSON file that tells the browser about your
web application and how it should behave when installed on the user's mobile
device or desktop. You can specify a manifest in your `mkdocs.yml` :
2018-11-18 05:51:35 +13:00
```yaml
extra:
2018-11-17 17:57:47 +01:00
manifest: 'manifest.webmanifest'
2018-11-18 05:51:35 +13:00
```
2018-11-17 17:57:47 +01:00
[21]: https://developers.google.com/web/fundamentals/web-app-manifest/
### More advanced customization
If you want to change the general appearance of the Material theme, see
[this article][22] for more information on advanced customization.
[22]: customization.md
2017-10-31 19:42:43 +01:00
## Integrations
2016-12-29 17:55:08 +01:00
2017-11-05 14:26:44 +01:00
### Google Analytics
2016-03-12 13:21:06 +01:00
2016-12-29 17:55:08 +01:00
MkDocs makes it easy to integrate site tracking with Google Analytics.
Besides basic tracking, clicks on all outgoing links can be tracked as well as
how site search is used. Tracking can be activated in your project's
`mkdocs.yml` :
2016-03-12 13:21:06 +01:00
``` yaml
google_analytics:
- 'UA-XXXXXXXX-X'
- 'auto'
```
2017-11-05 14:26:44 +01:00
### Disqus
2017-02-24 22:53:12 +01:00
2018-11-17 17:57:47 +01:00
Material for MkDocs is integrated with [Disqus][23], so if you want to add a
2017-02-24 22:53:12 +01:00
comments section to your documentation set the shortname of your Disqus project
in your `mkdocs.yml` :
``` yaml
extra:
2018-02-11 19:04:29 +01:00
disqus: 'your-shortname'
2017-02-24 22:53:12 +01:00
```
2017-11-03 14:25:37 +01:00
The comments section is inserted on *every page, except the index page* .
2017-07-25 16:24:20 +02:00
Additionally, a new entry at the bottom of the table of contents is generated
that is linking to the comments section. The necessary JavaScript is
automatically included.
2017-02-24 22:53:12 +01:00
2017-05-31 15:31:17 +02:00
!!! warning "Requirements"
2017-07-18 15:35:03 +09:00
`site_url` value must be set in `mkdocs.yml` for the Disqus integration to
2017-05-31 15:31:17 +02:00
load properly.
2017-05-21 00:49:30 +05:30
2018-11-17 17:57:47 +01:00
Disqus can also be enabled or disabled for specific pages using [Metadata][24].
2018-02-11 19:18:33 +01:00
2018-11-17 17:57:47 +01:00
[23]: https://disqus.com
[24]: extensions/metadata.md#disqus
2016-02-09 21:59:37 +01:00
## Extensions
2018-11-17 17:57:47 +01:00
MkDocs supports several [Markdown extensions][25]. The following extensions
2017-01-07 20:07:41 +01:00
are not enabled by default (see the link for which are enabled by default)
but highly recommended, so they should be switched on at all times:
2016-02-09 21:59:37 +01:00
``` yaml
markdown_extensions:
- admonition
2017-10-18 21:38:33 +02:00
- codehilite:
2017-10-16 13:13:05 -04:00
guess_lang: false
- toc:
permalink: true
2016-02-09 21:59:37 +01:00
```
2016-12-29 17:55:08 +01:00
For more information, see the following list of extensions supported by the
Material theme including more information regarding installation and usage:
2016-02-21 18:30:49 +01:00
2018-11-17 17:57:47 +01:00
* [Admonition][26]
* [Codehilite][27]
* [Footnotes][28]
* [Metadata][29]
* [Permalinks][30]
* [PyMdown Extensions][31]
[25]: https://www.mkdocs.org/user-guide/writing-your-docs/#markdown -extensions
[26]: extensions/admonition.md
[27]: extensions/codehilite.md
[28]: extensions/footnotes.md
[29]: extensions/metadata.md
[30]: extensions/permalinks.md
[31]: extensions/pymdown.md
2016-02-09 21:59:37 +01:00
2019-06-15 15:47:53 +02:00
## Plugins
2019-12-18 17:13:17 +01:00
MkDocs's plugin architecture makes it possible to add pre- or post-processing steps that sit between the theme and your documentation. For more information, see the following list of plugins tested and supported by the Material theme including more information regarding installation and usage:
2019-06-15 15:47:53 +02:00
2019-12-18 17:13:17 +01:00
* [Minify HTML][32]
* [Revision date][33]
* [Search][34]
2019-06-15 15:47:53 +02:00
2019-12-18 17:13:17 +01:00
The MkDocs wiki contains a [list of all available plugins][35].
2019-06-15 15:47:53 +02:00
!!! warning "Remember to re-add the `search` plugin"
2019-12-18 17:13:17 +01:00
If you have no `plugins` entry in your config file yet, you'll likely also want to add the `search` plugin when adding additional plugins. MkDocs enables it by default if there is no `plugins` entry set.
2019-06-15 15:47:53 +02:00
2019-12-18 17:13:17 +01:00
[32]: plugins/minify-html.md
[33]: plugins/revision-date.md
[34]: plugins/search.md
[35]: https://github.com/mkdocs/mkdocs/wiki/MkDocs-Plugins
2019-06-15 15:47:53 +02:00
2016-02-09 21:59:37 +01:00
## Full example
2016-08-07 18:01:56 +02:00
Below is a full example configuration for a `mkdocs.yml` :
2016-02-09 21:59:37 +01:00
``` yaml
# Project information
2017-11-05 14:26:44 +01:00
site_name: 'Material for MkDocs'
site_description: 'A Material Design theme for MkDocs'
site_author: 'Martin Donath'
site_url: 'https://squidfunk.github.io/mkdocs-material/'
2016-02-09 21:59:37 +01:00
# Repository
2017-11-05 14:26:44 +01:00
repo_name: 'squidfunk/mkdocs-material'
repo_url: 'https://github.com/squidfunk/mkdocs-material'
2016-02-09 21:59:37 +01:00
# Copyright
2017-11-05 14:26:44 +01:00
copyright: 'Copyright © 2016 - 2017 Martin Donath'
2016-02-09 21:59:37 +01:00
2017-10-31 19:42:43 +01:00
# Configuration
theme:
name: 'material'
2017-10-19 21:01:57 +02:00
language: 'en'
2016-02-24 17:31:01 +01:00
palette:
primary: 'indigo'
2016-12-29 17:55:08 +01:00
accent: 'indigo'
2016-02-17 18:08:11 +01:00
font:
text: 'Roboto'
code: 'Roboto Mono'
2017-10-31 19:42:43 +01:00
# Customization
extra:
2018-11-17 17:57:47 +01:00
manifest: 'manifest.webmanifest'
2016-12-29 17:55:08 +01:00
social:
- type: 'github'
2017-11-05 14:26:44 +01:00
link: 'https://github.com/squidfunk'
2016-12-29 17:55:08 +01:00
- type: 'twitter'
2017-11-05 14:26:44 +01:00
link: 'https://twitter.com/squidfunk'
2016-12-29 17:55:08 +01:00
- type: 'linkedin'
2019-12-18 16:32:21 +09:00
link: 'https://www.linkedin.com/in/squidfunk'
2016-02-09 21:59:37 +01:00
2016-03-12 13:21:06 +01:00
# Google Analytics
google_analytics:
- 'UA-XXXXXXXX-X'
- 'auto'
2016-02-09 21:59:37 +01:00
# Extensions
markdown_extensions:
- admonition
2017-10-16 13:13:05 -04:00
- codehilite:
guess_lang: false
- toc:
permalink: true
2016-02-09 21:59:37 +01:00
```