navigation-menu.html.twig

Same filename in other branches
  1. 11.x core/modules/navigation/templates/navigation-menu.html.twig
{% import _self as menus %}
{% set menu_heading_id = 'menu--' ~ menu_name|clean_unique_id %}
<div class="admin-toolbar__item">
  <h4 id="{{ menu_heading_id }}" class="toolbar-block__title visually-hidden focusable">{{ title }}</h4>
  <ul class="toolbar-block__list" aria-labelledby="{{ menu_heading_id }}">
    {{ menus.menu_items(items, attributes, 0) }}
  </ul>
</div>

{% macro menu_items(items, attributes, menu_level) %}
  {% for item in items %}

    {% set item_link_tag = 'a' %}

    {% if item.url.isRouted %}
      {% if item.url.routeName == '<nolink>' %}
        {% set item_link_tag = constant('\\Drupal\\Core\\GeneratedNoLink::TAG') %}
      {% elseif item.url.routeName == '<button>' %}
        {% set item_link_tag = constant('\\Drupal\\Core\\GeneratedButton::TAG') %}
      {% endif %}
    {% endif %}

    {% if item.url.options.attributes is empty %}
      {% set item_link_attributes = create_attribute() %}
    {% else %}
      {% set item_link_attributes = create_attribute(item.url.options.attributes) %}
    {% endif %}

    {% set item_id = ('navigation-link--' ~ item.original_link.pluginId)|clean_unique_id %}
    {% if menu_level == 0 %}
      {% if item.below is empty %}
        <li id="{{ item_id }}" class="toolbar-block__list-item">
          {% include '@navigation/toolbar-button.html.twig' with {
            attributes: item_link_attributes.setAttribute('href', item.url|render|default(null)).setAttribute('data-drupal-tooltip', item.title).setAttribute('data-drupal-tooltip-class', 'admin-toolbar__tooltip'),
            icon: item.class|clean_class,
            html_tag: item_link_tag,
            text: item.title,
            extra_classes: 'toolbar-button--collapsible ' ~ (item_link_tag == 'span' ? 'toolbar-button--non-interactive'),
          } only %}
        </li>
      {% else %}
        <li id="{{ item_id }}" class="toolbar-block__list-item toolbar-popover" data-toolbar-popover>
          {% include '@navigation/toolbar-button.html.twig' with {
            action: true,
            attributes: create_attribute({'aria-expanded': 'false', 'aria-controls': item_id, 'data-toolbar-popover-control': true}),
            icon: item.class|clean_class,
            text: item.title,
            extra_classes: 'toolbar-button--expand--side toolbar-button--collapsible toolbar-popover__control',
            has_safe_triangle: TRUE,
          } only %}
          <div class="toolbar-popover__wrapper" data-toolbar-popover-wrapper inert>
            {% if item.url %}
              {{ link(item.title, item.url, item_link_attributes.addClass(['toolbar-popover__header', 'toolbar-button', 'toolbar-button--large', 'toolbar-button--dark'])) }}
            {% else %}
              <span class="toolbar-popover__header toolbar-button toolbar-button--large toolbar-button--dark toolbar-button--non-interactive">{{ item.title }}</span>
            {% endif %}
            <ul class="toolbar-menu toolbar-popover__menu">
              {{ menus.menu_items(item.below, attributes, 1) }}
            </ul>
          </div>
        </li>
      {% endif %}

    {% elseif menu_level == 1 %}
      <li class="toolbar-menu__item toolbar-menu__item--level-{{ menu_level }}">
        {% if item.below is empty  %}
          {% include '@navigation/toolbar-button.html.twig' with {
            attributes: item_link_attributes.setAttribute('href', item.url|render|default(null)),
            text: item.title,
            html_tag: item_link_tag,
            extra_classes: item_link_tag == 'span' ? 'toolbar-button--non-interactive',
          } only %}
        {% else %}
          <button
            class="toolbar-button toolbar-button--expand--down"
            data-toolbar-menu-trigger="{{ menu_level }}"
            aria-expanded="false"
            data-index-text="{{ item.title|first|lower }}"
          >
            <span class="toolbar-menu__link-action visually-hidden">{{ 'Extend'|t }}</span>
            <span class="toolbar-menu__link-title">{{ item.title }}</span>
          </button>
          <ul class="toolbar-menu toolbar-menu--level-{{ menu_level + 1 }}" inert>
            {{ menus.menu_items(item.below, attributes, menu_level + 1) }}
          </ul>
        {% endif %}
      </li>
    {% else %}
      <li class="toolbar-menu__item toolbar-menu__item--level-{{ menu_level }}">
        {% if item.below is empty  %}
          {{ link(item.title, item.url, {
            'class': [
              'toolbar-menu__link',
              'toolbar-menu__link--' ~ menu_level,
            ],
            'data-index-text': item.title|first|lower
          }) }}
        {% else %}
          <button
            class="toolbar-menu__link toolbar-menu__link--{{ menu_level }}"
            data-toolbar-menu-trigger="{{ menu_level }}"
            aria-expanded="false"
            data-index-text="{{ item.title|first|lower }}"
          >
            <span class="toolbar-menu__link-action visually-hidden">{{ 'Extend'|t }}</span>
            <span class="toolbar-menu__link-title">{{ item.title }}</span>
          </button>
          <ul class="toolbar-menu toolbar-menu--level-{{ menu_level + 1 }}" inert>
            {{ menus.menu_items(item.below, attributes, menu_level + 1) }}
          </ul>
        {% endif %}
      </li>
    {% endif %}
  {% endfor %}
{% endmacro %}
1 theme call to navigation-menu.html.twig
ShortcutLazyBuilder::lazyLinks in core/modules/navigation/src/ShortcutLazyBuilder.php
The #lazy_builder callback; builds shortcut navigation links.

File

core/modules/navigation/templates/navigation-menu.html.twig

View source
  1. {% import _self as menus %}
  2. {% set menu_heading_id = 'menu--' ~ menu_name|clean_unique_id %}
  3. <div class="admin-toolbar__item">
  4. <h4 id="{{ menu_heading_id }}" class="toolbar-block__title visually-hidden focusable">{{ title }}</h4>
  5. <ul class="toolbar-block__list" aria-labelledby="{{ menu_heading_id }}">
  6. {{ menus.menu_items(items, attributes, 0) }}
  7. </ul>
  8. </div>
  9. {% macro menu_items(items, attributes, menu_level) %}
  10. {% for item in items %}
  11. {% set item_link_tag = 'a' %}
  12. {% if item.url.isRouted %}
  13. {% if item.url.routeName == '<nolink>' %}
  14. {% set item_link_tag = constant('\\Drupal\\Core\\GeneratedNoLink::TAG') %}
  15. {% elseif item.url.routeName == '<button>' %}
  16. {% set item_link_tag = constant('\\Drupal\\Core\\GeneratedButton::TAG') %}
  17. {% endif %}
  18. {% endif %}
  19. {% if item.url.options.attributes is empty %}
  20. {% set item_link_attributes = create_attribute() %}
  21. {% else %}
  22. {% set item_link_attributes = create_attribute(item.url.options.attributes) %}
  23. {% endif %}
  24. {% set item_id = ('navigation-link--' ~ item.original_link.pluginId)|clean_unique_id %}
  25. {% if menu_level == 0 %}
  26. {% if item.below is empty %}
  27. <li id="{{ item_id }}" class="toolbar-block__list-item">
  28. {% include '@navigation/toolbar-button.html.twig' with {
  29. attributes: item_link_attributes.setAttribute('href', item.url|render|default(null)).setAttribute('data-drupal-tooltip', item.title).setAttribute('data-drupal-tooltip-class', 'admin-toolbar__tooltip'),
  30. icon: item.class|clean_class,
  31. html_tag: item_link_tag,
  32. text: item.title,
  33. extra_classes: 'toolbar-button--collapsible ' ~ (item_link_tag == 'span' ? 'toolbar-button--non-interactive'),
  34. } only %}
  35. </li>
  36. {% else %}
  37. <li id="{{ item_id }}" class="toolbar-block__list-item toolbar-popover" data-toolbar-popover>
  38. {% include '@navigation/toolbar-button.html.twig' with {
  39. action: true,
  40. attributes: create_attribute({'aria-expanded': 'false', 'aria-controls': item_id, 'data-toolbar-popover-control': true}),
  41. icon: item.class|clean_class,
  42. text: item.title,
  43. extra_classes: 'toolbar-button--expand--side toolbar-button--collapsible toolbar-popover__control',
  44. has_safe_triangle: TRUE,
  45. } only %}
  46. <div class="toolbar-popover__wrapper" data-toolbar-popover-wrapper inert>
  47. {% if item.url %}
  48. {{ link(item.title, item.url, item_link_attributes.addClass(['toolbar-popover__header', 'toolbar-button', 'toolbar-button--large', 'toolbar-button--dark'])) }}
  49. {% else %}
  50. <span class="toolbar-popover__header toolbar-button toolbar-button--large toolbar-button--dark toolbar-button--non-interactive">{{ item.title }}</span>
  51. {% endif %}
  52. <ul class="toolbar-menu toolbar-popover__menu">
  53. {{ menus.menu_items(item.below, attributes, 1) }}
  54. </ul>
  55. </div>
  56. </li>
  57. {% endif %}
  58. {% elseif menu_level == 1 %}
  59. <li class="toolbar-menu__item toolbar-menu__item--level-{{ menu_level }}">
  60. {% if item.below is empty %}
  61. {% include '@navigation/toolbar-button.html.twig' with {
  62. attributes: item_link_attributes.setAttribute('href', item.url|render|default(null)),
  63. text: item.title,
  64. html_tag: item_link_tag,
  65. extra_classes: item_link_tag == 'span' ? 'toolbar-button--non-interactive',
  66. } only %}
  67. {% else %}
  68. <button
  69. class="toolbar-button toolbar-button--expand--down"
  70. data-toolbar-menu-trigger="{{ menu_level }}"
  71. aria-expanded="false"
  72. data-index-text="{{ item.title|first|lower }}"
  73. >
  74. <span class="toolbar-menu__link-action visually-hidden">{{ 'Extend'|t }}</span>
  75. <span class="toolbar-menu__link-title">{{ item.title }}</span>
  76. </button>
  77. <ul class="toolbar-menu toolbar-menu--level-{{ menu_level + 1 }}" inert>
  78. {{ menus.menu_items(item.below, attributes, menu_level + 1) }}
  79. </ul>
  80. {% endif %}
  81. </li>
  82. {% else %}
  83. <li class="toolbar-menu__item toolbar-menu__item--level-{{ menu_level }}">
  84. {% if item.below is empty %}
  85. {{ link(item.title, item.url, {
  86. 'class': [
  87. 'toolbar-menu__link',
  88. 'toolbar-menu__link--' ~ menu_level,
  89. ],
  90. 'data-index-text': item.title|first|lower
  91. }) }}
  92. {% else %}
  93. <button
  94. class="toolbar-menu__link toolbar-menu__link--{{ menu_level }}"
  95. data-toolbar-menu-trigger="{{ menu_level }}"
  96. aria-expanded="false"
  97. data-index-text="{{ item.title|first|lower }}"
  98. >
  99. <span class="toolbar-menu__link-action visually-hidden">{{ 'Extend'|t }}</span>
  100. <span class="toolbar-menu__link-title">{{ item.title }}</span>
  101. </button>
  102. <ul class="toolbar-menu toolbar-menu--level-{{ menu_level + 1 }}" inert>
  103. {{ menus.menu_items(item.below, attributes, menu_level + 1) }}
  104. </ul>
  105. {% endif %}
  106. </li>
  107. {% endif %}
  108. {% endfor %}
  109. {% endmacro %}

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.