Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Pass menu label attributes to translation #6092

Closed
wants to merge 12 commits into from
Closed
10 changes: 5 additions & 5 deletions docs/reference/advanced_configuration.rst
Original file line number Diff line number Diff line change
Expand Up @@ -306,19 +306,19 @@ If you want to use the Tab Menu in a different way, you can replace the Menu Tem
Translations
^^^^^^^^^^^^

The translation parameters and domain can be customised by using the
``translation_domain`` and ``translation_parameters`` keys of the extra array
The label translation parameters and domain can be customised by using the
``label_translation_parameters`` and ``label_catalogue`` keys of the extra array
of data associated with the item, respectively::

$menuItem->setExtras([
'translation_parameters' => ['myparam' => 'myvalue'],
'translation_domain' => 'My domain',
'label_translation_parameters' => ['myparam' => 'myvalue'],
'label_catalogue' => 'My domain',
]);

You can also set the translation domain on the menu root, and children will
inherit it::

$menu->setExtra('translation_domain', 'My domain');
$menu->setExtra('label_catalogue', 'My domain');

Filter parameters
^^^^^^^^^^^^^^^^^
Expand Down
52 changes: 32 additions & 20 deletions src/Resources/views/Menu/sonata_menu.html.twig
Original file line number Diff line number Diff line change
@@ -1,43 +1,43 @@
{% extends 'knp_menu.html.twig' %}

{% block root %}
{%- set listAttributes = item.childrenAttributes|merge({'class': 'sidebar-menu', 'data-widget': 'tree'}) %}
{%- set request = item.extra('request') ?: app.request %}
{%- set listAttributes = item.childrenAttributes|merge({'class': 'sidebar-menu', 'data-widget': 'tree'}) -%}
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm not sure of the impact of adding - in all the tag of block root, block item, etc.

Maybe it's better to limit the change to block label in order to avoid regression.
But I let the choice to other reviewers.

{%- set request = item.extra('request') ?: app.request -%}
{{ block('list') -}}
{% endblock %}

{% block item %}
{%- if item.displayed %}
{%- if item.displayed -%}
{#- check role of the group #}
{%- set display = item.extra('roles') is empty or is_granted(sonata_admin.adminPool.getOption('role_super_admin')) or item.extra('roles')|filter(role => is_granted(role))|length > 0 %}
{%- endif %}
{%- set display = item.extra('roles') is empty or is_granted(sonata_admin.adminPool.getOption('role_super_admin')) or item.extra('roles')|filter(role => is_granted(role))|length > 0 -%}
{%- endif -%}

{%- if item.displayed and display|default %}
{% set options = options|merge({branch_class: 'treeview', currentClass: "active", ancestorClass: "active"}) %}
{%- do item.setChildrenAttribute('class', (item.childrenAttribute('class')~' active')|trim) %}
{%- do item.setChildrenAttribute('class', (item.childrenAttribute('class')~' treeview-menu')|trim) %}
{%- if item.displayed and display|default -%}
{%- set options = options|merge({branch_class: 'treeview', currentClass: "active", ancestorClass: "active"}) -%}
{%- do item.setChildrenAttribute('class', (item.childrenAttribute('class')~' active')|trim) -%}
{%- do item.setChildrenAttribute('class', (item.childrenAttribute('class')~' treeview-menu')|trim) -%}
{{ parent() }}
{% endif %}
{%- endif -%}
{% endblock %}

{% block linkElement %}
{% apply spaceless %}
{% set translation_domain = item.extra('label_catalogue', 'messages') %}
{% if item.extra('on_top') is defined and not item.extra('on_top') %}
{% set icon = item.extra('icon')|default(item.level > 1 ? '<i class="fa fa-angle-double-right" aria-hidden="true"></i>' : '') %}
{% else %}
{% set icon = item.extra('icon') %}
{% endif %}
{% set is_link = true %}
{%- set translation_domain = item.extra('label_catalogue', 'messages') -%}
{%- if item.extra('on_top') is defined and not item.extra('on_top') -%}
{%- set icon = item.extra('icon')|default(item.level > 1 ? '<i class="fa fa-angle-double-right" aria-hidden="true"></i>' : '') -%}
{%- else -%}
{%- set icon = item.extra('icon') -%}
{%- endif -%}
{%- set is_link = true -%}
{{ parent() }}
{% endapply %}
{% endblock %}

{% block spanElement %}
{% apply spaceless %}
<a href="#">
{% set translation_domain = item.extra('label_catalogue') %}
{% set icon = item.extra('icon')|default('') %}
{%- set translation_domain = item.extra('label_catalogue', 'messages') -%}
{%- set icon = item.extra('icon')|default('') -%}
{{ icon|raw }}
{{ parent() }}
{%- if item.extra('keep_open') is not defined or not item.extra('keep_open') -%}
Expand All @@ -47,4 +47,16 @@
{% endapply %}
{% endblock %}

{% block label %}{% if is_link is defined and is_link %}{{ icon|default|raw }}{% endif %}{% if options.allow_safe_labels and item.extra('safe_label', false) %}{{ item.label|raw }}{% else %}{{ item.label|trans({}, translation_domain|default('messages')) }}{% endif %}{% endblock %}
{% block label %}
{% apply spaceless %}
{%- if is_link is defined and is_link -%}
{{ icon|default|raw }}
{%- endif -%}
{%- if options.allow_safe_labels and item.extra('safe_label', false) -%}
{{ item.label|raw }}
{%- else -%}
{%- set translation_domain = item.extra('label_catalogue', 'messages') -%}
{{ item.label|trans(item.extra('label_translation_parameters', {}), translation_domain) }}
{%- endif -%}
{% endapply %}
{% endblock %}