Defining Navigation

Defining Navigation

The menu items for managing the content in the admin panel.

In the backend area, entries will be listed under the Content menu item with globals listed under the Settings menu item (by default). You may control this behavior using the navigation property in the blueprint file. The following code will set an icon and specify the order of appearance.

navigation:
    icon: icon-pencil
    order: 200

The following properties are supported by the navigation and primaryNavigation definition.

Property Description
label specifies the menu label localization string key, required.
order a numerical weight when determining the display order.
parent links the navigation item to a parent item using a blueprint handle.
icon an icon name from the October CMS icon collection, optional.
iconSvg an SVG icon to be used in place of the standard icon, the SVG icon should be a rectangle and can support colors, optional.

To place an item in the Settings area, set the parent to settings. The category definition can be a string or a settings constant reference, eg. CATEGORY_COLLECTIONS.

navigation:
    parent: settings
    category: Collections

To place an item in the Content area, set the parent to content.

navigation:
    parent: content

To place the item as a primary navigation item. A primaryNavigation definition is needed.

primaryNavigation:
    label: Blog
    icon: icon-copy
    order: 500

navigation:
    label: Main Menu Item

To place the item as a secondary navigation item. The parent property should specify the UUID or handle of a primary navigation item.

navigation:
    parent: <handle|uuid>

To disable the secondary navigation, define the primaryNavigation for a single blueprint without it being a parent for any other blueprints.

primaryNavigation:
    label: Page
    icon: icon-magic
    order: 500

You may also completely disable the navigation by setting the navigation property to false.

navigation: false

# Extra Navigation

Use the extraNavigation property to register custom navigation items to include with the blueprint. The value is an array matching the sideMenu definition found in the backend navigation specification. The following example includes two a section and divider using custom display types, the order property is used to align the items in the correct order.

navigation:
    label: Authors
    parent: Blog\Post
    icon: icon-user
    order: 230

extraNavigation:
    _authors_section:
        itemType: section
        label: Authors
        order: 210

    _authors_ruler:
        itemType: ruler
        order: 220

You may also register links to controllers introduced by plugins by specifying the url property. This property should be set to the controller URL, the following links to the acme/blog/posts controller.

navigation:
    label: Authors
    # ...

extraNavigation:
    testimonials:
        label: Testimonials
        order: 210
        icon: icon-group
        url: acme/blog/posts

To set the navigation context inside the controller, use the setTailorContext method on the BackendMenu facade. You may also specify the blueprint uuid with the setTailorContextUuid method. The method takes the handle or uuid of the blueprint (first argument), and the key used by the extra navigation item (second argument).

BackendMenu::setTailorContext('Blog\Post', 'testimonials');

BackendMenu::setTailorContextUuid('edcd102e-0525-4e4d-b07e-633ae6c18db6', 'testimonials');

# See Also

On This Page