mirror of
https://github.com/snachodog/just-the-docs.git
synced 2025-04-06 04:01:22 -06:00
This PR combines (and resolves conflicts between) #448, #463, #466, #494, #495, #496, #498, and #572. The main aim is to facilitate use of several of the implemented features _together_, when using the fork as a remote theme. It should also simplify merging the included PRs into a future release. The branch [combination-rec-nav](https://github.com/pdmosses/just-the-docs/tree/combination-rec-nav) adds [multi-level navigation](https://github.com/pmarsceill/just-the-docs/pull/462) and (NEW:) [sibling links](https://github.com/pmarsceill/just-the-docs/pull/394) to the branch used for this PR. It includes updated [documentation for the navigation structure](https://pdmosses.github.io/just-the-docs/docs/navigation-structure/), and reorganised and extended [navigation tests](https://pdmosses.github.io/just-the-docs/tests/navigation/). The documentation and the tests can be browsed at the (temporary) [website published from the combination-rec-nav branch](https://pdmosses.github.io/just-the-docs/). _Caveat:_ The changes to v0.3.3 in this PR and #462 have not yet been reviewed or approved, and may need updating before merging into a release of the theme. If you use a branch from a PR as a remote theme, there is a risk of such updates affecting your website. Moreover, these branches are likely to be deleted after they have been merged. To avoid such problems, you could copy the branch that you want to use to your own fork of the theme. Co-authored-by: Matt Wang <matt@matthewwang.me>
258 lines
8.2 KiB
Markdown
258 lines
8.2 KiB
Markdown
---
|
|
layout: default
|
|
title: Configuration
|
|
nav_order: 2
|
|
---
|
|
|
|
# Configuration
|
|
{: .no_toc }
|
|
|
|
Just the Docs has some specific configuration parameters that can be defined in your Jekyll site's \_config.yml file.
|
|
{: .fs-6 .fw-300 }
|
|
|
|
## Table of contents
|
|
{: .no_toc .text-delta }
|
|
|
|
1. TOC
|
|
{:toc}
|
|
|
|
---
|
|
|
|
View this site's [\_config.yml](https://github.com/just-the-docs/just-the-docs/tree/main/_config.yml) file as an example.
|
|
|
|
## Site logo
|
|
|
|
```yaml
|
|
# Set a path/url to a logo that will be displayed instead of the title
|
|
logo: "/assets/images/just-the-docs.png"
|
|
```
|
|
|
|
## Search
|
|
|
|
```yaml
|
|
# Enable or disable the site search
|
|
# Supports true (default) or false
|
|
search_enabled: true
|
|
|
|
search:
|
|
# Split pages into sections that can be searched individually
|
|
# Supports 1 - 6, default: 2
|
|
heading_level: 2
|
|
# Maximum amount of previews per search result
|
|
# Default: 3
|
|
previews: 3
|
|
# Maximum amount of words to display before a matched word in the preview
|
|
# Default: 5
|
|
preview_words_before: 5
|
|
# Maximum amount of words to display after a matched word in the preview
|
|
# Default: 10
|
|
preview_words_after: 10
|
|
# Set the search token separator
|
|
# Default: /[\s\-/]+/
|
|
# Example: enable support for hyphenated search words
|
|
tokenizer_separator: /[\s/]+/
|
|
# Display the relative url in search results
|
|
# Supports true (default) or false
|
|
rel_url: true
|
|
# Enable or disable the search button that appears in the bottom right corner of every page
|
|
# Supports true or false (default)
|
|
button: false
|
|
```
|
|
|
|
## Aux links
|
|
|
|
```yaml
|
|
# Aux links for the upper right navigation
|
|
aux_links:
|
|
"Just the Docs on GitHub":
|
|
- "//github.com/just-the-docs/just-the-docs"
|
|
|
|
# Makes Aux links open in a new tab. Default is false
|
|
aux_links_new_tab: false
|
|
```
|
|
|
|
## Heading anchor links
|
|
|
|
```yaml
|
|
# Heading anchor links appear on hover over h1-h6 tags in page content
|
|
# allowing users to deep link to a particular heading on a page.
|
|
#
|
|
# Supports true (default) or false
|
|
heading_anchors: true
|
|
```
|
|
|
|
## Footer content
|
|
|
|
```yaml
|
|
# Footer content
|
|
# appears at the bottom of every page's main content
|
|
# Note: The footer_content option is deprecated and will be removed in a future major release. Please use `_includes/footer_custom.html` for more robust
|
|
markup / liquid-based content.
|
|
footer_content: "Copyright © 2017-2020 Patrick Marsceill. Distributed by an <a href=\"https://github.com/just-the-docs/just-the-docs/tree/main/LICENSE.txt\">MIT license.</a>"
|
|
|
|
# Footer last edited timestamp
|
|
last_edit_timestamp: true # show or hide edit time - page must have `last_modified_date` defined in the frontmatter
|
|
last_edit_time_format: "%b %e %Y at %I:%M %p" # uses ruby's time format: https://ruby-doc.org/stdlib-2.7.0/libdoc/time/rdoc/Time.html
|
|
|
|
# Footer "Edit this page on GitHub" link text
|
|
gh_edit_link: true # show or hide edit this page link
|
|
gh_edit_link_text: "Edit this page on GitHub."
|
|
gh_edit_repository: "https://github.com/just-the-docs/just-the-docs" # the github URL for your repo
|
|
gh_edit_branch: "main" # the branch that your docs is served from
|
|
# gh_edit_source: docs # the source that your files originate from
|
|
gh_edit_view_mode: "tree" # "tree" or "edit" if you want the user to jump into the editor immediately
|
|
```
|
|
|
|
_note: `footer_content` is deprecated, but still supported. For a better experience we have moved this into an include called `_includes/footer_custom.html` which will allow for robust markup / liquid-based content._
|
|
|
|
- the "page last modified" data will only display if a page has a key called `last_modified_date`, formatted in some readable date format
|
|
- `last_edit_time_format` uses Ruby's DateTime formatter; see examples and more information [at this link.](https://apidock.com/ruby/DateTime/strftime)
|
|
- `gh_edit_repository` is the URL of the project's GitHub repository
|
|
- `gh_edit_branch` is the branch that the docs site is served from; defaults to `main`
|
|
- `gh_edit_source` is the source directory that your project files are stored in (should be the same as [site.source](https://jekyllrb.com/docs/configuration/options/))
|
|
- `gh_edit_view_mode` is `"tree"` by default, which brings the user to the github page; switch to `"edit"` to bring the user directly into editing mode
|
|
|
|
## Color scheme
|
|
|
|
```yaml
|
|
# Color scheme supports "light" (default) and "dark"
|
|
color_scheme: dark
|
|
```
|
|
|
|
<button class="btn js-toggle-dark-mode">Preview dark color scheme</button>
|
|
|
|
<script>
|
|
const toggleDarkMode = document.querySelector('.js-toggle-dark-mode');
|
|
|
|
jtd.addEvent(toggleDarkMode, 'click', function(){
|
|
if (jtd.getTheme() === 'dark') {
|
|
jtd.setTheme('light');
|
|
toggleDarkMode.textContent = 'Preview dark color scheme';
|
|
} else {
|
|
jtd.setTheme('dark');
|
|
toggleDarkMode.textContent = 'Return to the light side';
|
|
}
|
|
});
|
|
</script>
|
|
|
|
See [Customization]({{ site.baseurl }}{% link docs/customization.md %}) for more information.
|
|
|
|
## Callouts
|
|
|
|
To use this feature, you need to configure a `color` and (optionally) `title` for each kind of callout you want to use, e.g.:
|
|
|
|
```yaml
|
|
callouts:
|
|
warning:
|
|
title: Warning
|
|
color: red
|
|
```
|
|
|
|
This uses the color `$red-000` for the background of the callout, and `$red-300` for the title and box decoration.[^dark] You can then style a paragraph as a `warning` callout like this:
|
|
|
|
```markdown
|
|
{: .warning }
|
|
A paragraph...
|
|
```
|
|
|
|
[^dark]:
|
|
If you use the `dark` color scheme, this callout uses `$red-300` for the background, and `$red-000` for the title.
|
|
|
|
The colors `grey-lt`, `grey-dk`, `purple`, `blue`, `green`, `yellow`, and `red` are predefined; to use a custom color, you need to define its `000` and `300` levels in your SCSS files. For example, to use `pink`, add the following to your `_sass/custom/custom.scss` file:
|
|
|
|
```scss
|
|
$pink-000: #f77ef1;
|
|
$pink-100: #f967f1;
|
|
$pink-200: #e94ee1;
|
|
$pink-300: #dd2cd4;
|
|
```
|
|
|
|
You can override the default `opacity` of the background for a particular callout, e.g.:
|
|
|
|
```yaml
|
|
callouts:
|
|
custom:
|
|
color: pink
|
|
opacity: 0.3
|
|
```
|
|
|
|
You can change the default opacity (`0.2`) for all callouts, e.g.:
|
|
|
|
```yaml
|
|
callouts_opacity: 0.3
|
|
```
|
|
|
|
You can also adjust the overall level of callouts.
|
|
The value of `callouts_level` is either `quiet` or `loud`;
|
|
`loud` increases the saturation and lightness of the backgrounds.
|
|
The default level is `quiet` when using the `light` or custom color schemes,
|
|
and `loud` when using the `dark color scheme.`
|
|
|
|
See [Callouts]({{ site.baseurl }}{% link docs/ui-components/callouts.md %}) for more information.
|
|
|
|
## Google Analytics
|
|
|
|
```yaml
|
|
# Google Analytics Tracking (optional)
|
|
# e.g, UA-1234567-89
|
|
ga_tracking: UA-5555555-55
|
|
ga_tracking_anonymize_ip: true # Use GDPR compliant Google Analytics settings (true by default)
|
|
```
|
|
|
|
## Document collections
|
|
|
|
By default, the navigation and search include normal [pages](https://jekyllrb.com/docs/pages/).
|
|
You can also use [Jekyll collections](https://jekyllrb.com/docs/collections/) which group documents semantically together.
|
|
|
|
For example, put all your test files in the `_tests` folder and create the `tests` collection:
|
|
|
|
```yaml
|
|
# Define Jekyll collections
|
|
collections:
|
|
# Define a collection named "tests", its documents reside in the "_tests" directory
|
|
tests:
|
|
permalink: "/:collection/:path/"
|
|
output: true
|
|
|
|
just_the_docs:
|
|
# Define which collections are used in just-the-docs
|
|
collections:
|
|
# Reference the "tests" collection
|
|
tests:
|
|
# Give the collection a name
|
|
name: Tests
|
|
# Exclude the collection from the navigation
|
|
# Supports true or false (default)
|
|
# nav_exclude: true
|
|
# Fold the collection in the navigation
|
|
# Supports true or false (default)
|
|
# nav_fold: true
|
|
# Exclude the collection from the search
|
|
# Supports true or false (default)
|
|
# search_exclude: true
|
|
```
|
|
The navigation for all your normal pages (if any) is displayed before those in collections.
|
|
|
|
You can reference multiple collections.
|
|
This creates categories in the navigation with the configured names.
|
|
|
|
```yaml
|
|
collections:
|
|
tests:
|
|
permalink: "/:collection/:path/"
|
|
output: true
|
|
tutorials:
|
|
permalink: "/:collection/:path/"
|
|
output: true
|
|
|
|
just_the_docs:
|
|
collections:
|
|
tests:
|
|
name: Tests
|
|
tutorials:
|
|
name: Tutorials
|
|
```
|
|
When *all* your pages are in a single collection, its name is not displayed.
|
|
|
|
The navigation for each collection is a separate name space for page titles: a page in one collection cannot be a child of a page in a different collection, or of a normal page.
|