fatfish/navigation

Craft navigation for the website.

Installs: 1 664

Dependents: 0

Suggesters: 0

Security: 0

Stars: 7

Watchers: 2

Forks: 6

Type:craft-plugin

1.0.8.13-beta 2020-03-03 02:49 UTC

README

PHPCS check

Craft navigation plugin for the website.

Screenshot

Requirements

This plugin requires Craft CMS 3.0.0-beta.23 or later.

Installation

To install the plugin, follow these instructions.

  1. Open your terminal and go to your Craft project:

     cd /path/to/project
    
  2. Then tell Composer to load the plugin:

     composer require fatfish/navigation
    
  3. In the Control Panel, go to Settings → Plugins and click the “Install” button for Navigation.

Navigation Overview

Navigation is a simple menu builder for Craft CMS 3.x

Screenshot

  1. Click on create Menu, Give your menu a name.
  2. Choose your entries by clicking on entry button or click on external link if you want add external link
  3. Save Menu

Voila you are done !.

Templating

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 %}
{% endif %} {% endmacro %}

  • {% 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