Client Area Navigation Menus

You can customize the Client Area’s navigation menus through hooks and custom modules.

For more information about customizing Client Area navigation links, see our Developer Documentation.

There are two navigation bars in the Client Area:

  • The primary navigation bar contains the bulk of the menu and floats to the left of the secondary navigation bar.
  • The secondary navigation bar contains user-specific items and changes if a client is logged in to WHMCS.
    • For visitors who have not logged in, the secondary navigation contains a login link.
    • When a client is logged in, the secondary menu contains links to the client’s account.

Client Area navigation bar links remain consistent across all devices and screen resolutions, and customizations to them will persist through updates.

The navigation menus in the Client Area use a tree structure of menu item objects. Each menu item has one parent item and can have many child items. The only menu item with no parent is an invisible root item that does not appear on the page.

Navigation bars consist of the invisible menu root with children representing every item in the navigation bar. Each of these items may have their own child items. These child items render that navigation bar item’s menu.

  • Navigation bar root Item
    • navigation item
    • navigation item
      • menu item
    • navigation item
      • menu item
      • menu item
      • menu item
    • navigation item

Client Area Layout

The way in which navigation bars display depends on the Client Area layout. The Client Area displays in two layouts, Desktop Mode or Responsive Mode.

  • Desktop Mode typically appears in desktop web browsers.
  • Responsive Mode activates when the Client Area renders on a smaller screen like a phone or tablet.
For more information about the Client Area layouts and how they determine navigation display, see Client Area Layout.

The Item class models menu items, including both navigation bars and sidebars.

Menu item arrangement for the navigation bar

These objects contain all the information to render that menu item within a template, including their parent and child menu item relationships. Menu items can have the following aspects:

  • A single parent item.
  • Multiple optional child items.
  • An internal name for the menu item.
  • A label to display when the item appears on the page. If there is not a defined label, WHMCS renders the menu item’s name.
  • A URI to link to when the user clicks or taps on a menu item.
  • An optional icon to the left of the label. WHMCS has access to both the Glyphicons and Font Awesome libraries.
  • An optional badge to the right of the label, usually for contextual information, like the number of tickets in a status next to that status’s name.
  • The display order for a menu item in its parent’s list of children.

In navigation bars, all of the menu item’s children render as menu items.

All menu items include icons to the left of a link to the menu item’s URI and the menu item’s badge.

Finding a Menu Item Name

Every menu item has a unique name that references it. You can find the name of each menu item available in the HTML source of the page, using the Inspect Element option in most modern browsers.

For example:

Finding a menu item name using Inspect Element

In this example, Account is the parent menu item and Account Details is the menu item.

Because the navigation menus use a tree structure, you must retrieve both the parent menu item name and the child menu item name.

Hooks

Hooks allow menu interaction before the template renders the menu. Use WHMCS’s add_hook() function to call custom code when WHMCS reaches these hook points during page generation.

The following table lists the available hooks, when the system calls them, and what they pass to the hook function:

HookCalledPassed Items
ClientAreaPrimaryNavbarPrior to rendering navigation bars.The primary navigation bar object.
ClientAreaSecondaryNavbarPrior to rendering navigation bars.The secondary navigation bar object.
ClientAreaNavbarsPrior to rendering navigation bars.N/A
In WHMCS 8.5 and later, you can use the CustomActions server module function to add items to the server details sidebar menu. The item will perform a set function and then redirect the user to a specified URL. For more information, see Client Area Homepage Panels and our Developer Documentation.

Direct Access

WHMCS allows direct manipulation of menu objects outside the hooks system for modules and other custom code that doesn’t use the hooks system. The built-in Menu class is an alias to an object repository that can retrieve all of WHMCS’s menu objects. If the system has not generated the menu yet, normal page generation may overwrite an empty menu structure.

We strongly recommend using the hooks system to interact with menus.

The Menu class has four static methods to retrieve menus:

  • Item Menu::primaryNavbar() — Retrieve the primary navigation bar.
  • Item Menu::secondaryNavbar() — Retrieve the secondary navigation bar.

Context

WHMCS’s menus and sidebars render information that is specific to the page that the user accessed. For example, client information passes to Account () > My Account while ticket information passes to the list of support tickets. This data is passes to menu item objects as context.

For more information, see Menu and Sidebar Context.

Last modified: January 2, 2025