clone of olivero for island lives
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

76 lines
2.5 KiB

12 months ago
{#
/**
* @file
* Theme override for status messages.
*
* Displays status, error, and warning messages, grouped by type.
*
* An invisible heading identifies the messages for assistive technology.
* Sighted users see a colored box. See
* https://www.w3.org/TR/WCAG-TECHS/H69.html for info.
*
* Add an ARIA label to the contentinfo area so that assistive technology
* user agents will better describe this landmark.
*
* Available variables:
* - message_list: List of messages to be displayed, grouped by type.
* - status_headings: List of all status types.
* - attributes: HTML attributes for the element, including:
* - class: HTML classes.
*/
#}
{{ attach_library('olives/messages') }}
<div data-drupal-messages class="messages-list">
<div class="messages__wrapper layout-container">
{% for type, messages in message_list %}
{%
set classes = [
'messages-list__item',
'messages',
'messages--' ~ type,
]
%}
<div{{ attributes
.addClass(classes)
.setAttribute('data-drupal-selector', 'messages')
.setAttribute('role', 'contentinfo')
.setAttribute('aria-label', status_headings[type])
}}>
<div class="messages__container" data-drupal-selector="messages-container"{% if type == 'error' %} role="alert"{% endif %}>
{% if status_headings[type] %}
<div class="messages__header">
<h2 class="visually-hidden">{{ status_headings[type] }}</h2>
<div class="messages__icon">
{% if type == 'error' %}
{% include "@olives/../images/error.svg" %}
{% elseif type == 'warning' %}
{% include "@olives/../images/warning.svg" %}
{% elseif type == 'status' %}
{% include "@olives/../images/status.svg" %}
{% elseif type == 'info' %}
{% include "@olives/../images/info.svg" %}
{% endif %}
</div>
</div>
{% endif %}
<div class="messages__content">
{% if messages|length > 1 %}
<ul class="messages__list">
{% for message in messages %}
<li class="messages__item">{{ message }}</li>
{% endfor %}
</ul>
{% else %}
{{ messages|first }}
{% endif %}
</div>
</div>
</div>
{# Remove type specific classes. #}
{% set attributes = attributes.removeClass(classes) %}
{% endfor %}
</div>
</div>