8202518c4457e28c601d22240e32975b4258ae95
[yaffs-website] / web / core / profiles / demo_umami / themes / umami / templates / components / navigation / menu.html.twig
1 {#
2 /**
3  * @file
4  * Theme override to display a menu.
5  *
6  * Available variables:
7  * - menu_name: The machine name of the menu.
8  * - items: A nested list of menu items. Each menu item contains:
9  *   - attributes: HTML attributes for the menu item.
10  *   - below: The menu item child items.
11  *   - title: The menu link title.
12  *   - url: The menu link url, instance of \Drupal\Core\Url
13  *   - localized_options: Menu link localized options.
14  *   - is_expanded: TRUE if the link has visible children within the current
15  *     menu tree.
16  *   - is_collapsed: TRUE if the link has children within the current menu tree
17  *     that are not currently visible.
18  *   - in_active_trail: TRUE if the link is in the active trail.
19  */
20 #}
21
22 {% import _self as menus %}
23
24 {#
25   We call a macro which calls itself to render the full tree.
26   @see http://twig.sensiolabs.org/doc/tags/macro.html
27
28   1. We use menu_name (see above) to create a CSS class name from it.
29   See https://www.drupal.org/node/2649076
30 #}
31 {{ menus.menu_links(items, attributes, 0, menu_name) }} {# 1. #}
32
33 {% macro menu_links(items, attributes, menu_level, menu_name) %} {# 1. #}
34   {% import _self as menus %}
35   {# 1. #}
36   {%
37     set menu_classes = [
38       'menu-' ~ menu_name|clean_class,
39     ]
40   %}
41   {# 1. #}
42   {%
43     set submenu_classes = [
44       'menu-' ~ menu_name|clean_class ~ '__submenu',
45     ]
46   %}
47   {% if items %}
48     {% if menu_level == 0 %}
49       <ul{{ attributes.addClass(menu_classes) }}> {# 1. #}
50     {% else %}
51       <ul{{ attributes.removeClass(menu_classes).addClass(submenu_classes) }}> {# 1. #}
52     {% endif %}
53     {% for item in items %}
54       {# 1. #}
55       {%
56         set item_classes = [
57           'menu-' ~ menu_name|clean_class ~ '__item',
58           item.is_expanded ? 'menu-' ~ menu_name|clean_class ~ '__item--expanded',
59           item.is_collapsed ? 'menu-' ~ menu_name|clean_class ~ '__item--collapsed',
60           item.in_active_trail ? 'menu-' ~ menu_name|clean_class ~ '__item--active-trail',
61         ]
62       %}
63       {# 1. #}
64       {%
65         set link_classes = [
66           'menu-' ~ menu_name|clean_class ~ '__link',
67         ]
68       %}
69       <li{{ item.attributes.addClass(item_classes) }}>{# 1. #}
70         {# 1. #}
71         {{
72           link(
73             item.title,
74             item.url,
75             item.attributes.removeClass(item_classes).addClass(link_classes)
76           )
77         }}
78         {% if item.below %}
79           {{ menus.menu_links(item.below, attributes, menu_level + 1, menu_name) }} {# 1. #}
80         {% endif %}
81       </li>
82     {% endfor %}
83     </ul>
84   {% endif %}
85 {% endmacro %}