As of: Winter '22
Authored By: George Abboud
Last Updated: 11/22/2021
Reviews and Contributions:
Craig Johnson, Manish Aggarwal, Yelena Kamyshina, David Goldbrenner
AppExchange Listing: https://appexchange.salesforce.com/appxListingDetail?listingId=a0N4V00000FZbCXUA1
Open-Source GitHub Repository: https://github.com/SalesforceLabs/MultiLevelNavigationMenus
The Multi-Level Navigation Menu for Experience Cloud app offers components to manage multi-level navigation menus, and render them in your Experience Cloud site. You can configure up to 6 levels of depth in your menus, control the look and feel with styling configuration, horizontal vs vertical presentation, language filtering support, and much more!
This package is free to use, but is not an official salesforce.com product, and should be considered a community project. The functionality is not officially tested or documented, and does not come with any support, warrantees, or updates. It is offered as-is.
Access the Lightning App called “Community Menus” from the Lightning experience as an admin or a user who is given access to that app and underlying objects (ccnavmenus__Menu__c, ccnavmenus__Menu_Item__c). The home page of the app will run the Menus Manager component (menusManager), which uses an apex controller called “menusManagerController.cls”. Ensure that any user needing to run this functionality also has access to that apex class to be able to run the Menus Manager component.
When a menu is not selected, you will have two enabled buttons:
- New Menu: Opens a modal in which you can create a new menu record (layout is based on assigned page layout)
- Import Menu: Opens a modal in which you can select a .json file that you had previously exported, to import the menu based on
When a menu is selected, you will have a few addition buttons enabled:
- Edit Menu: Opens a modal in which you can edit the selected menu record (layout is based on assigned page layout)
- Delete Menu: Opens a modal in which you are asked to confirm the intent to delete the selected menu record. Note: This will also delete all child menu items
- Export Menu: Prompts user to save a .json file that is an export of the selected menu in JSON format.
- Create Menu Item: Opens a modal in which you are able to create a first-level menu item record (layout is hard coded and NOT based on page layout)
Creating menu items:
- Create the first menu item by clicking Create Menu Item after a Menu is selected.
- Create child menu items by clicking the arrow to the right of the parent menu item.
- The position assigned to the menu item is always in relation to sibling menu items
Using Translations:
- There are 2 options for multi-lingual Nav Menus: 1. Create separate menu item per language or 2. Create a single menu with multiple languages
Component Label: CC Navigation Menu
Component Aura API Name: navMenu
Component LWC API Name: nav-menu
Component Namespace: ccnavmenus
Component Properties:
Property Label | Aura Property API Name | LWC Property API Name | Type | Description |
---|---|---|---|---|
Menu | menuId | menu-id | String | (required) Choose which menu to display. If "[Name Filter]" is chosen, you have to provide a matching value in the Name Filter property to match the Menu record's Name field. Defaults to "[Name Filter]" |
Name Filter | nameFilter | name-filter | String | (optional) Provide a value to match a menu's Name on. The value can be hardcoded, or a merge field such as {!recordId}, {!recordName} {!urlParameter}. Using merge fields can facilitate creating dynamic menu's based for pages with dynamic variables. |
Vertical? | isVertical | is-vertical | Boolean | If checked (true) the menu will render in vertical (tree) mode, otherwise it renders horizontally. Defaults to false and renders horizontally. |
Language | language | language | String | (required) Provide a language to filter menu on. If 'auto' is chosen, for unauthenticated / guest users the language is populated based on the language picker component ('language' url parameter), otherwise for authenticated users the language is based on their language / locale selection in their user settings. If translation is not needed, set to 'none' value. Valid options are "none", "auto" |
Hamburger Menu Mode | hamburgerMenuMode | hamburger-menu-mode | String | Mode for when to hide menu behind hamburger. Defaults to 'mobile-only' which will render a hamburger menu only on mobile devices. 'on' will render a hamburger menu all the time. 'off' will never render a hamburger menu. |
URL Substition Map JSON | urlSubMapJson | url-sub-map-json | String | (optional) Provide a JSON map for substituting tokens in menu item url fields with the replacement values defined in the map being passed. Example: [{"replaceThis":"[!recordId]", "replaceWith":"{!recordId}"}] This would replace urls that have [!recordId] in them, with the value of the recordId on a page that has that recordId populated. |
Override Navigation Text Color | brandNavigationColorText | brand-navigation-color-text | String | (optional) Provide color code to override the Navigation Text Color inherited from the theme |
Override Navigation Bar Background Color | brandNavigationBarBackgroundColor | brand-navigation-bar-background-color | String | (optional) Provide color code to override the Navigation Bar Background Color inherited from the theme |
Override Navigation Background Color | brandNavigationBackgroundColor | brand-navigation-background-color | String | (optional) Provide color code to override the Navigation Background Color inherited from the theme |
Override Font Family | fontFamily | font-family | String | (optional) Provide Font Family to override the Font Family inherited from the theme |
Override Text Case | textTransform | text-transform | String | (optional) Provide Text Case to override the Text Case inherited from the theme. Valid values are: "inherit", "none", "capitalize", "lowercase". The default value is "inherit" |
Top Level Item Spacing | topLevelItemSpacing | top-level-item-spacing | Integer | (required) Set spacing in pixels between Top Level Menu Items. |
Menu Style Classes | navMenuClassNames | nav-menu-class-names | String | (optional) Class names to uniquely target a menu's styles. |
The Multi-Level Navigation Menu lightning component and underlying data model follow the Salesforce platform’s security and sharing concepts.
- In order for a user to be able to run the component, the user has to be granted access to the Apex Controller “ccnavmenus__menusController” (either via profile or permission set).
- Since the apex controller runs in “with sharing” mode, in order for the user to be able to successfully query and render a menu, the following needs to occur:
- The user must be granted “Read” CRUD permission to both the “Menu” and “Menu Item” objects (either via profile or permission set).
- The user must be granted “Read” FLS permission to all fields on both the “Menu” and “Menu Item” objects.
- The user must be granted “Read” access to the “Menu” records that you want them to be able to render on the Experience Cloud site. For guest (unauthenticated) users, you will need to create Guest User Sharing Rules to open up access to “Menu” records. For authenticated users, you will need to share the “Menu” records in one of the many options you have on the platform to do so.
<ccnavmenus:navMenu
menuId="a005w00000bz2FQAAY"
nameFilter=""
isVertical="{!v.isVertical}"
language="none"
hamburgerMenuMode="mobile-only"
urlSubMapJson="{!v.urlSubMapJson}"
brandNavigationColorText="rgba(255,255,255,1)"
brandNavigationBarBackgroundColor="rgba(255,255,255,1)"
brandNavigationBackgroundColor="rgba(255,255,255,1)"
fontFamily="Salesforce Sans"
textTransform="uppercase"
topLevelItemSpacing="20"
/>
From a declarative perspective, this component cannot be used to swap out the nav menu in the header from theme settings. This is due to the unavailability of a nav menu interface to implement that would allow for such a swap. The availability of this interface is currently not on the product roadmap.
From a development perspective, including this component in a custom LWC behaves differently, depending on if you’re using your custom component in LWR vs Aura Runtime. In LWR, you can use a custom LWC which includes the “ccnavmenus-nav-menu”. On the other hand, in Aura Runtime you cannot use a custom LWC that includes other LWCs from different namespaces due to Locker Service limitations.
- This component can be called in the markup of any Aura lightning component. An Aura lightning component serving as a custom theme layout would make it possible to swap out the standard navigation menu with this navigation menu component instead.
- This component can be dragged / dropped into a “shared” header region of the theme, declaratively, if such a region is available in the selected theme.
- This component can be dragged / dropped into any page in builder to be used at a page level if needed.
- Multi-level support for up to 6 levels deep
- URLs - supports fully qualified and relative urls
- Control whether each menu item opens in the same or a new window
- Control whether each menu item is available for the public / guest / unauthenticated user
- Support for languages and localization
- Choose an icon for each menu item and control whether it is placed on the left or right of the label, or no icon at all
- Export / Import menus for ease of maintenance and deployment from one org to another
- Display a menu vertically or horizontally. When vertical, if url of page matches a menu item’s url, it is automatically expanded and highlighted
- (Advanced) Use Name Filters and hardcoded values or merge fields to match menu names and render different menus dynamically.
- (Advanced) Provide JSON token maps to replace tokens you leave in menu item urls, with the values specified in your map (including support for merge fields)
- Use the power of audience targeting to target different menus for different audiences
- LWR Ready
Installation URL: https://login.salesforce.com/packaging/installPackage.apexp?p0=04t5w000005mRLm
- LWR Ready
- Style inheritance and fixes
Installation URL: https://login.salesforce.com/packaging/installPackage.apexp?p0=04t5w000005b3Yx
- Fix for updating public property in renderedCallback causing infinite loop
Installation URL: https://login.salesforce.com/packaging/installPackage.apexp?p0=04t5w000005b3Y s
- browser console error fixes, nav menu style classes property
Installation URL: https://login.salesforce.com/packaging/installPackage.apexp?p0=04t5w000005b3H2
- Bug fix for click on parent div of a menu link
Installation URL: https://login.salesforce.com/packaging/installPackage.apexp?p0=04t5w000005b38J
- Bug fix for chevron icon click next to a linked menu item not expanding/collapsing child items
Installation URL: https://login.salesforce.com/packaging/installPackage.apexp?p0=04t5w000005b389
- Bug fix for click on icon in a menu item not going to url
Installation URL: https://login.salesforce.com/packaging/installPackage.apexp?p0=04t5w000005b2oQ
- Accessibility Fixes
Installation URL: https://login.salesforce.com/packaging/installPackage.apexp?p0=04t5w000005b2oL
- Styling Fixes
- Added RelaxedCSP capability
Installation URL: https://login.salesforce.com/packaging/installPackage.apexp?p0=04t5w000005b2kE
- Fixed errors from locker service
Installation URL: https://login.salesforce.com/packaging/installPackage.apexp?p0=04t5w000004Gpxg
- Fixed issue with hamburger menu not closing upon navigation
Installation URL: https://login.salesforce.com/packaging/installPackage.apexp?p0=04t5w000004Gps1
- Fixed issue with Winter ’21 input field’s readonly attribute not passing values to record being created / updated
Installation URL: https://login.salesforce.com/packaging/installPackage.apexp?p0=04t5w000004Gprw
- Styling updates and fixes
Installation URL: https://login.salesforce.com/packaging/installPackage.apexp?p0=04t5w000005uZyE
- Added CRUD / FLS checks based on security review feedback
Installation URL: https://login.salesforce.com/packaging/installPackage.apexp?p0=04t5w000005uZds
- Fixed clicking on url to close the popup when menu is in horizontal mode
- Fixed double row actions in menu manager
- Fixed action popup in menu manager to be to the left of the button icon
- Changed language selection when creating or editing menu item to be within accordion
Installation URL: https://login.salesforce.com/packaging/installPackage.apexp?p0=04t5w000005uZdi
- Initial Release