2021-08-25 11:33:29 +00:00
+++
title = "Pages organization"
weight = 5
+++
2017-07-30 16:02:07 +00:00
2017-08-20 15:10:29 +00:00
In **Hugo** , pages are the core of your site. Once it is configured, pages are definitely the added value to your documentation site.
2017-07-30 16:02:07 +00:00
## Folders
Organize your site like [any other Hugo project ](https://gohugo.io/content/organization/ ). Typically, you will have a *content* folder with all your pages.
2021-08-23 22:25:15 +00:00
````plaintext
content
├── level-one
│ ├── level-two
│ │ ├── level-three
│ │ │ ├── level-four
│ │ │ │ ├── _index.md < -- / level-one / level-two / level-three / level-four
│ │ │ │ ├── page-4-a.md < -- / level-one / level-two / level-three / level-four / page-4-a
│ │ │ │ ├── page-4-b.md < -- / level-one / level-two / level-three / level-four / page-4-b
│ │ │ │ └── page-4-c.md < -- / level-one / level-two / level-three / level-four / page-4-c
│ │ │ ├── _index.md < -- / level-one / level-two / level-three
│ │ │ ├── page-3-a.md < -- / level-one / level-two / level-three / page-3-a
│ │ │ ├── page-3-b.md < -- / level-one / level-two / level-three / page-3-b
│ │ │ └── page-3-c.md < -- / level-one / level-two / level-three / page-3-c
│ │ ├── _index.md < -- / level-one / level-two
│ │ ├── page-2-a.md < -- / level-one / level-two / page-2-a
│ │ ├── page-2-b.md < -- / level-one / level-two / page-2-b
│ │ └── page-2-c.md < -- / level-one / level-two / page-2-c
│ ├── _index.md < -- / level-one
│ ├── page-1-a.md < -- / level-one / page-1-a
│ ├── page-1-b.md < -- / level-one / page-1-b
│ └── page-1-c.md < -- / level-one / page-1-c
├── _index.md < -- /
└── page-top.md < -- / page-top
````
2017-08-20 15:10:29 +00:00
{{% notice note %}}
`_index.md` is required in each folder, it’ s your “folder home page”
2017-07-30 16:02:07 +00:00
{{% /notice %}}
## Types
2021-06-30 12:56:06 +00:00
**Hugo-theme-relearn** defines two types of pages. *Default* and *Chapter* . Both can be used at any level of the documentation, the only difference being layout display.
2017-07-30 16:02:07 +00:00
2017-08-20 15:10:29 +00:00
A **Chapter** displays a page meant to be used as introduction for a set of child pages. Commonly, it contains a simple title and a catch line to define content that can be found under it.
2017-07-30 16:02:07 +00:00
You can define any HTML as prefix for the menu. In the example below, it's just a number but that could be an [icon ](https://fortawesome.github.io/Font-Awesome/ ).
2021-06-30 19:30:03 +00:00
![Chapter page ](images/pages-chapter.png?width=50pc )
2017-07-30 16:02:07 +00:00
2017-08-20 15:10:29 +00:00
```markdown
+++
chapter = true
pre = "< b > 1. < / b > "
2021-08-25 11:33:29 +00:00
title = "Basics"
weight = 5
2017-08-20 15:10:29 +00:00
+++
2017-07-30 16:02:07 +00:00
2017-08-20 15:10:29 +00:00
### Chapter 1
2017-07-30 16:02:07 +00:00
2017-08-20 15:10:29 +00:00
# Basics
2017-07-30 16:02:07 +00:00
2017-08-20 15:10:29 +00:00
Discover what this Hugo theme is all about and the core-concepts behind it.
```
2017-07-30 16:02:07 +00:00
2021-06-30 12:56:06 +00:00
To tell **Hugo-theme-relearn** to consider a page as a chapter, set `chapter=true` in the Front Matter of the page.
2017-08-20 20:29:35 +00:00
2017-08-20 15:10:29 +00:00
A **Default** page is any other content page.
2017-07-30 16:02:07 +00:00
2021-06-30 19:30:03 +00:00
![Default page ](images/pages-default.png?width=50pc )
2017-07-30 16:02:07 +00:00
2017-08-20 15:10:29 +00:00
```toml
+++
title = "Installation"
weight = 15
+++
```
2017-07-30 16:02:07 +00:00
2017-08-20 15:10:29 +00:00
The following steps are here to help you initialize your new website. If you don't know Hugo at all, we strongly suggest you to train by following this [great documentation for beginners ](https://gohugo.io/overview/quickstart/ ).
2017-07-30 16:02:07 +00:00
2017-08-20 15:10:29 +00:00
## Create your project
2017-07-30 16:02:07 +00:00
2017-08-20 15:10:29 +00:00
Hugo provides a `new` command to create a new website.
2017-07-30 16:02:07 +00:00
2021-08-23 21:32:34 +00:00
```shell
2017-08-20 15:10:29 +00:00
hugo new site < new_project >
```
2017-07-30 16:02:07 +00:00
2021-07-01 19:47:17 +00:00
**Hugo-theme-relearn** provides [archetypes ]({{%relref "cont/archetypes.en.md" %}} ) to help you create this kind of pages.
2017-07-30 16:02:07 +00:00
2017-08-20 15:10:29 +00:00
## Front Matter configuration
2017-07-30 16:02:07 +00:00
2021-08-25 11:33:29 +00:00
Each Hugo page has to define a [Front Matter ](https://gohugo.io/content/front-matter/ ) in *toml* , *yaml* or *json* . This site will use *toml* in all cases.
2017-07-30 16:02:07 +00:00
2021-06-30 12:56:06 +00:00
**Hugo-theme-relearn** uses the following parameters on top of Hugo ones :
2017-07-30 16:02:07 +00:00
```toml
+++
2021-08-23 21:51:52 +00:00
# Table of contents (toc) is enabled by default. Set this parameter to true to disable it.
2017-08-20 15:10:29 +00:00
# Note: Toc is always disabled for chapter pages
disableToc = "false"
2017-11-19 13:48:37 +00:00
# If set, this will be used for the page's menu entry (instead of the `title` attribute)
menuTitle = ""
2021-08-24 22:10:09 +00:00
# If set, this will explicitly override common rules for the expand state of a page's menu entry
alwaysopen = true
2017-08-20 15:10:29 +00:00
# The title of the page in menu will be prefixed by this HTML content
pre = ""
# The title of the page in menu will be postfixed by this HTML content
post = ""
# Set the page as a chapter, changing the way it's displayed
chapter = false
# Hide a menu entry by setting this to true
hidden = false
2018-08-10 08:18:13 +00:00
# Display name of this page modifier. If set, it will be displayed in the footer.
2017-08-20 15:10:29 +00:00
LastModifierDisplayName = ""
# Email of this page modifier. If set with LastModifierDisplayName, it will be displayed in the footer
LastModifierEmail = ""
2017-07-30 16:02:07 +00:00
+++
```
2017-08-20 15:10:29 +00:00
### Add icon to a menu entry
2017-07-30 16:02:07 +00:00
2017-08-20 15:10:29 +00:00
In the page frontmatter, add a `pre` param to insert any HTML code before the menu label. The example below uses the Github icon.
2017-07-30 16:02:07 +00:00
2017-08-20 15:10:29 +00:00
```toml
+++
2021-07-01 14:25:08 +00:00
title = "GitHub repo"
2018-02-19 11:10:41 +00:00
pre = "< i class = 'fab fa-github' > < / i > "
2017-08-20 15:10:29 +00:00
+++
```
2017-07-30 16:02:07 +00:00
2021-06-30 19:30:03 +00:00
![Title with icon ](images/frontmatter-icon.png )
2017-07-30 16:02:07 +00:00
2017-08-20 15:10:29 +00:00
### Ordering sibling menu/page entries
2017-07-30 16:02:07 +00:00
2017-08-20 15:10:29 +00:00
Hugo provides a [flexible way ](https://gohugo.io/content/ordering/ ) to handle order for your pages.
The simplest way is to set `weight` parameter to a number.
```toml
+++
title = "My page"
weight = 5
+++
```
2017-11-19 13:48:37 +00:00
### Using a custom title for menu entries
2021-06-30 12:56:06 +00:00
By default, **Hugo-theme-relearn** will use a page's `title` attribute for the menu item (or `linkTitle` if defined).
2017-11-19 13:48:37 +00:00
2018-08-10 08:18:13 +00:00
But a page's title has to be descriptive on its own while the menu is a hierarchy.
2017-11-19 13:48:37 +00:00
We've added the `menuTitle` parameter for that purpose:
2018-08-10 08:18:13 +00:00
For example (for a page named `content/install/linux.md` ):
2017-11-19 13:48:37 +00:00
```toml
+++
title = "Install on Linux"
menuTitle = "Linux"
+++
```
2021-08-24 22:10:09 +00:00
### Override expand state rules for menu entries
You can change how the theme expands menu entries on the side of the content with the `alwaysopen` setting on a per page basis. If `alwaysopen=false` for any given entry, its children will not be shown in the menu as long as it is not necessary for the sake of navigation.
The theme generates the menu based on the following rules:
- all parent entries of the active page including their siblings are shown regardless of any settings
- immediate children entries of the active page are shown regardless of any settings
- if not overridden, all other first level entries behave like they would have been given `alwaysopen=false`
- if not overridden, all other entries of levels besides the first behave like they would have been given `alwaysopen=true`
- all visible entries show their immediate children entries if `alwaysopen=true` ; this proceeds recursivley
- all remaining entries are not shown
You can see this feature in action on the example page for [children shortcode ]({{< relref "shortcodes/children" >}} ) and its children pages.
2017-08-20 15:10:29 +00:00
## Homepage
2017-07-30 16:02:07 +00:00
2017-08-20 15:10:29 +00:00
To configure your home page, you basically have three choices:
2017-07-30 16:02:07 +00:00
2017-08-20 15:10:29 +00:00
1. Create an `_index.md` document in `content` folder and fill the file with *Markdown content*
2. Create an `index.html` file in the `static` folder and fill the file with *HTML content*
3. Configure your server to automatically redirect home page to one your documentation page