uswds_paragraph_components-1.0.x-dev/templates/paragraph--uswds-step-indicator-list.html.twig

templates/paragraph--uswds-step-indicator-list.html.twig
{#
/**
 * @file
 * Default theme implementation to display a paragraph in USWDS Paragraph Components.
 *
 * Available variables:
 * - paragraph: Full paragraph entity.
 *   - id: The paragraph ID.
 *   - bundle: The type of the paragraph, for example, "image" or "text".
 *   - authorid: The user ID of the paragraph author.
 *   - createdtime: Formatted creation date. Preprocess functions can
 *     reformat it by calling format_date() with the desired parameters on
 *     $variables['paragraph']->getCreatedTime().
 * - content: All paragraph items. Use {{ content }} to print them all,
 *   or print a subset such as {{ content.field_example }}. Use
 *   {{ content|without('field_example') }} to temporarily suppress the printing
 *   of a given child element.
 * - attributes: HTML attributes for the containing element.
 *   The attributes.class element may contain one or more of the following
 *   classes:
 *   - paragraphs: The current template type (also known as a "theming hook").
 *   - paragraphs--type-[type]: The current paragraphs type. For example, if the paragraph is an
 *     "Image" it would result in "paragraphs--type--image". Note that the machine
 *     name will often be in a short form of the human readable label.
 *   - paragraphs--view-mode--[view_mode]: The View Mode of the paragraph; for example, a
 *     preview would result in: "paragraphs--view-mode--preview", and
 *     default: "paragraphs--view-mode--default".
 * - view_mode: View mode; for example, "preview" or "full".
 * - logged_in: Flag for authenticated user status. Will be true when the
 *   current user is a logged-in member.
 * - is_admin: Flag for admin user status. Will be true when the current user
 *   is an administrator.
 *
 * @see template_preprocess_paragraph()
 *
 * @ingroup themeable
 */
#}

{# The template default set classes. #}
{# Sets Paragraph ID as class. #}
{%
  set classes = [
  'paragraph',
  'paragraph--type--' ~ paragraph.bundle|clean_class,
  view_mode ? 'paragraph--view-mode--' ~ view_mode|clean_class,
  'paragraph--id--' ~ paragraph.id.value,
  'usa-step-indicator'
]
%}

{% set no_labels = content.field_no_labels['#items'].getString() ? ' usa-step-indicator--no-labels' %}
{% set centered = content.field_centered['#items'].getString() ? ' usa-step-indicator--center' %}
{% set counters = content.field_counters['#items'].getString() ? ' usa-step-indicator--counters' %}
{% set small_counters = content.field_small_counters['#items'].getString() ? ' usa-step-indicator--counters-sm' %}

{% set completed_item = 0 %}
{% set total = 0 %}
{% for key, item in content.field_step_indicator_items if key|first != '#' %}
  {% set total = total + 1 %}
  {% if item['#paragraph'].field_current.value == 1 %}
    {% set completed_item = loop.index %}
  {% endif %}
{% endfor %}

<div{{ attributes.addClass(classes) }} aria-label="progress">
  <ol class="usa-step-indicator__segments{{ no_labels }}{{ centered }}{{ counters }}{{ small_counters }}">
    {% for key, item in content.field_step_indicator_items if key|first != '#' %}
      {% if loop.index < completed_item %}
        <li class="usa-step-indicator__segment usa-step-indicator__segment--complete">
          <span class="usa-step-indicator__segment-label">{{ item['#paragraph'].field_item_title.value }}<span class="usa-sr-only">completed</span></span>
        </li>
      {% elseif loop.index == completed_item %}
        <li class="usa-step-indicator__segment usa-step-indicator__segment--current" aria-current="true">
          <span class="usa-step-indicator__segment-label">{{ item['#paragraph'].field_item_title.value }}</span>
        </li>
      {% else %}
        <li class="usa-step-indicator__segment">
          <span class="usa-step-indicator__segment-label">{{ item['#paragraph'].field_item_title.value }}<span class="usa-sr-only">not completed</span></span>
        </li>
      {% endif %}
    {% endfor %}
  </ol>
  <div class="usa-step-indicator__header">
    <h2 class="usa-step-indicator__heading">
      <span class="usa-step-indicator__heading-counter">
        <span class="usa-sr-only">Step</span>
        <span class="usa-step-indicator__current-step">{{ completed_item }}</span>
        <span class="usa-step-indicator__total-steps">of {{ total }}</span>
      </span>
      <span class="usa-step-indicator__heading-text">{{ content.field_header.0 }}</span>
    </h2>
  </div>
</div>

Главная | Обратная связь

drupal hosting | друпал хостинг | it patrol .inc