Craft navigation plugin for the website.
This plugin requires Craft CMS 3.0.0-beta.23 or later.
To install the plugin, follow these instructions.
-
Open your terminal and go to your Craft project:
cd /path/to/project
-
Then tell Composer to load the plugin:
composer require fatfish/navigation
-
In the Control Panel, go to Settings → Plugins and click the “Install” button for Navigation.
Navigation is a simple menu builder for Craft CMS 3.x
- Click on create Menu, Give your menu a name.
- Choose your entries by clicking on entry button or click on external link if you want add external link
- Save Menu
Voila you are done !.
craft.Navigation.render()
craft.Navigation.render() lets you build a menu with pre-built static templates. This function takes two parameters, menu name "menu_name" and menu styling options.
Menu style options contains arrays which have a 'div', 'ul', 'li', and 'a' element. Each element can have their own CSS class.
{{craft.Navigation.render('menu_name',{ wrapperClass : 'navbar',
ulClass: 'navbar-nav',
listClass: 'nav-item',
linkClass: 'nav-link'})}}
This plugin also lets you build menus using your own HTML and CSS, you can use it via Twig Macro.
Inorder to achieve this you need to use craft.Navigation.getRawNav(MenuName)
This will let you build your own HTML menu with Twig Macros.
Sample custom menu:
{% import _self as macros %} {% macro menu(node,menuId) %} {% import _self as macros %} {% set Grandchildren = craft.Navigation.renderChildren(node,menuId) %} {% if Grandchildren | length > (0) %}
-
{% for grandchildren in Grandchildren %}
- {{ grandchildren.NodeName }} {{ macros.menu(grandchildren.NodeId,grandchildren.menuId) }} {% endfor %}
-
{% set MenuNodes=craft.Navigation.getRawNav('MenuName') %}
{% if MenuNodes is defined %}
{% if MenuNodes is iterable %}
{% for MenuNode in MenuNodes %}
{% if MenuNode.ParenNode == (0) %}
{% if craft.Navigation.renderChildren(MenuNode.NodeId,MenuNode.menuId) is iterable %}
<li>
<a href="{% if craft.entries.id(MenuNode.NodeId).one().uri is defined %}/{{craft.entries.id(MenuNode.NodeId).one().uri}}{% else %}{{ MenuNode.menuUrl }} {% endif %}">{{ MenuNode.NodeName }}</a>
{% if craft.Navigation.renderChildren(MenuNode.NodeId,MenuNode.menuId) | length %}
<ul>
{% for childrenMenu in craft.Navigation.renderChildren(MenuNode.NodeId,MenuNode.menuId) %}
<li>
<a href="{% if craft.entries.id(childrenMenu.NodeId).one().uri is defined %}/{{craft.entries.id(childrenMenu.NodeId).one().uri}}{% else %}{{ childrenMenu.menuUrl }} {% endif %}">{{ childrenMenu.NodeName }}</a>
{{ macros.menu(childrenMenu.NodeId,childrenMenu.menuId) }}
</li>
{% endfor %}
</ul>
{% endif %}
</li>
{% else %}
{% endif %}
{% else %}
{% endif %}
{% endfor %}
{% endif %}
{% else %} {% endif %}
Brought to you by Fatfish