Introduction
HydePHP offers automatic navigation menu generation features, designed to take the pain out of creating navigation menus. While Hyde does its best to configure these menus automatically based on understanding your project files, you may want to customize them further.
There are two types of navigation menus in Hyde:
- Primary Navigation Menu: The main navigation menu appearing on most pages of your site. Unique features include dropdowns for subdirectories, depending on configuration.
- Documentation Sidebar: The sidebar on documentation pages with links to other documentation pages. Unique features include automatic grouping based on subdirectories.
This documentation will guide you through the customization process of the primary navigation menu. To learn about the documentation sidebar, visit the Documentation Pages documentation.
Internal Structure Overview
Internally, both navigation menu types extend the same base class and thus share core functionality. This means the configuration process is similar for both types, making the documentation applicable to both.
For a deeper understanding of the internal workings, refer to the Digging Deeper section.
Understanding Priorities
All navigation menu items have an internal priority value determining their order. Lower values place items higher in the menu. The default priority for pages is 999
, placing them last unless you specify a value. Some pages, like the index
page, are configured by default with the lowest priority of 0
.
Customization Options
Here's an overview of what you can customize in your navigation menus:
- Item labels: The text displayed in menu links
- Item priorities: Control the order in which links appear
- Item visibility: Choose to hide or show pages in the menu
- Item grouping: Group pages together in dropdowns or sidebar categories
Customization Methods
Hyde provides multiple ways to customize navigation menus to suit your needs:
- Front matter data in Markdown and Blade page files, applicable to all menu types
- Configuration in the
hyde
config file for main navigation items
Keep in mind that front matter data overrides dynamically inferred or config-defined priorities. While useful for quick one-off changes on small sites, it can make reordering items later on more challenging as you can't see the entire structure at once.
Additionally, general options for the entire navigation menus are also available in the hyde
config file.
Front Matter Configuration
Front matter options allow per-page customization of navigation menus. Here's a quick reference of available options:
navigation:
label: string # The displayed text in the navigation item link
priority: int # The page's priority for ordering (lower means higher up/first)
hidden: bool # Whether the page should be hidden from the navigation menu
group: string # Set main menu dropdown or sidebar group key
You only need to specify the keys you want to customize.
label
Customizes the text appearing in the navigation menu link for the page. If not set anywhere else, Hyde will search for a title in the page content or generate one from the filename.
navigation:
label: "My Custom Label"
priority
Controls the order in which the page appears in the navigation menu.
navigation:
priority: 10
hidden
Determines if the page appears in the navigation menu.
navigation:
hidden: true
Tip: You can also use visible: false
to achieve the same effect.
group
For the primary navigation menu, this groups pages together in dropdowns. For the sidebar, it groups pages under a common heading.
navigation:
group: "My Group"
Note: Sidebar group keys are normalized, so My Group
and my-group
are equivalent.
Config File Configuration
Let's explore how to customize the main navigation menu using configuration files:
- For the main navigation menu, use the
navigation
setting in thehyde.php
config file.
When customizing the main navigation menu, use the route key of the page.
Changing Priorities
The navigation.order
setting allows you to customize the order of pages in the main navigation menu.
Basic Priority Syntax
A nice and simple way to define the order of pages is to add their route keys as a simple list array. We'll then match that array order.
It may be useful to know that we internally will assign a priority calculated according to its position in the list, plus an offset of 500
. The offset is added to make it easier to place pages earlier in the list using front matter or with explicit priority settings.
Filepath: config/hyde.php'navigation' => [
'order' => [
'home', // Priority: 500
'about', // Priority: 501
'contact', // Priority: 502
]
]
Explicit Priority Syntax
You can also specify explicit priorities by adding a value to the array keys. We'll then use these exact values as the priorities.
Filepath: config/hyde.php'navigation' => [
'order' => [
'home' => 10,
'about' => 15,
'contact' => 20,
]
]
You could also combine these methods if desired:
Filepath: config/hyde.php'navigation' => [
'order' => [
'home' => 10, // Priority: 10
'about', // Priority: 500
'contact', // Priority: 501
]
]
Changing Menu Item Labels
Hyde makes a few attempts to find suitable labels for the navigation menu items to automatically create helpful titles.
If you're not happy with these, it's easy to override navigation link labels by mapping the route key to the desired title in the Hyde config:
Filepath: config/hyde.php'navigation' => [
'labels' => [
'index' => 'Start',
'docs/index' => 'Documentation',
]
]
Excluding Items (Blacklist)
When you have many pages, it may be useful to prevent links from being added to the main navigation menu.
To exclude items from being added, simply add the page's route key to the navigation blacklist in the Hyde config:
Filepath: config/hyde.php'navigation' => [
'exclude' => [
'404'
]
]
Adding Custom Navigation Menu Links
You can easily add custom navigation menu links in the Hyde config:
Filepath: config/hyde.phpuse Hyde\Facades\Navigation;
'navigation' => [
'custom' => [
Navigation::item(
destination: 'https://github.com/hydephp/hyde', // Required
label: 'GitHub', // Optional, defaults to the destination value
priority: 200 // Optional, defaults to 500
),
]
]
Tip: While named arguments are used in the example for clarity, they are not required.
Configure Subdirectory Display
You can configure how subdirectories should be displayed in the menu:
Filepath: config/hyde.php'navigation' => [
'subdirectory_display' => 'dropdown'
]
Supported Options:
-
dropdown
: Pages in subdirectories are displayed in a dropdown menu -
hidden
: Pages in subdirectories are not displayed at all in the menus -
flat
: Pages in subdirectories are displayed as individual items
Automatic Menu Groups
A handy feature HydePHP has is that it can automatically place pages in dropdowns based on subdirectory structures.
Automatic Navigation Menu Dropdowns
Enable this feature in the hyde.php
config file by setting the subdirectory_display
key to dropdown
.
Filepath: config/hyde.php'navigation' => [
'subdirectory_display' => 'dropdown',
],
Now if you create a page called _pages/about/contact.md
, it will automatically be placed in a dropdown called "About".
Dropdown Menu Notes
- Dropdowns take priority over standard items. If you have a dropdown with the key
about
and a page with the keyabout
, the dropdown will be created, and the page won't be in the menu. - Example: With this file structure:
_pages/foo.md
,_pages/foo/bar.md
,_pages/foo/baz.md
, the link tofoo
will be lost, so please keep this in mind when using this feature.
Numerical Prefix Navigation Ordering
HydePHP v2 introduces navigation item ordering based on numerical prefixes in filenames. This feature works for the primary navigation menu.
This has the great benefit of matching the navigation menu layout with the file structure view. It also works especially well with subdirectory-based navigation grouping.
_pages/
01-home.md # Priority: 1 (saved to _site/index.html)
02-about.md # Priority: 2 (saved to _site/about.html)
03-contact.md # Priority: 3 (saved to _site/contact.html)
As you can see, Hyde parses the number from the filename and uses it as the priority for the page in navigation menus, while stripping the prefix from the route key.
Important Notes
- The numerical prefix remains part of the page identifier but is stripped from the route key.
For example:
_pages/01-home.md
has route keyhome
and page identifier01-home
. - You can delimit the numerical prefix with either a dash or an underscore.
For example: Both
_pages/01-home.md
and_pages/01_home.md
are valid. - Leading zeros are optional.
_pages/1-home.md
is equally valid.
Using Numerical Prefix Ordering in Subdirectories
This feature integrates well with automatic subdirectory-based navigation grouping. Here are two useful tips:
- You can use numerical prefixes in subdirectories to control the dropdown order.
- The numbering within a subdirectory works independently of its siblings, so you can start from one in each subdirectory.
Customization
If you're not interested in using numerical prefix ordering, you can disable it in the Hyde config file. Hyde will then no longer extract the priority and will no longer strip the prefix from the route key.
Filepath: config/hyde.php'numerical_page_ordering' => false,
Digging Deeper Into the Internals
While not essential, understanding the internal workings of the navigation system can be as beneficial as it's interesting. Here's a quick high-level overview of the Navigation API.
Navigation Menu Classes
The main navigation menu uses the MainNavigationMenu
class, while the documentation sidebar uses the DocumentationSidebar
class. Both extend the base NavigationMenu
class:
use Hyde\Framework\Features\Navigation\MainNavigationMenu;
use Hyde\Framework\Features\Navigation\DocumentationSidebar;
use Hyde\Framework\Features\Navigation\NavigationMenu;
The base NavigationMenu
class contains the main logic for menu generation, while child implementations contain extra logic for specific use cases.
All navigation menus store items in their $items
collection, containing instances of the NavigationItem
class. Dropdowns are represented by NavigationGroup
instances, which extend the NavigationMenu
class and contain additional NavigationItem
instances:
use Hyde\Framework\Features\Navigation\NavigationItem;
use Hyde\Framework\Features\Navigation\NavigationGroup;
The Navigation API
For advanced users and package developers, Hyde offers a Navigation API for programmatic interaction with site navigation. This API consists of a set of PHP classes allowing fluent interaction with navigation menus.
For more detailed information about the API, refer to the Navigation API documentation.