mirror of
https://github.com/Part-DB/Part-DB-server.git
synced 2026-02-24 18:39:35 +00:00
Use turbo-streams for handling updating locale menu in navbar
This commit is contained in:
parent
e2b43ba01f
commit
2ba0f2a95d
3 changed files with 16 additions and 39 deletions
|
|
@ -1,27 +0,0 @@
|
||||||
/*
|
|
||||||
* This file is part of Part-DB (https://github.com/Part-DB/Part-DB-symfony).
|
|
||||||
*
|
|
||||||
* Copyright (C) 2019 - 2022 Jan Böhmer (https://github.com/jbtronics)
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU Affero General Public License as published
|
|
||||||
* by the Free Software Foundation, either version 3 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU Affero General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU Affero General Public License
|
|
||||||
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
import { Controller } from '@hotwired/stimulus';
|
|
||||||
|
|
||||||
export default class extends Controller {
|
|
||||||
connect() {
|
|
||||||
const menu = document.getElementById('locale-select-menu');
|
|
||||||
menu.innerHTML = this.element.innerHTML;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
@ -159,7 +159,7 @@
|
||||||
<li role="separator" class="dropdown-divider"></li>
|
<li role="separator" class="dropdown-divider"></li>
|
||||||
<h6 class="dropdown-header">{% trans %}user.language_select{% endtrans %}</h6>
|
<h6 class="dropdown-header">{% trans %}user.language_select{% endtrans %}</h6>
|
||||||
<div id="locale-select-menu">
|
<div id="locale-select-menu">
|
||||||
{# This menu is filled by 'turbo/locale_menu' controller from the _turbo_control.html.twig template, to always have the correct path #}
|
{# This menu is filled by a turbo-stream in _turbo_contro.html.twig #}
|
||||||
</div>
|
</div>
|
||||||
</ul>
|
</ul>
|
||||||
</li>
|
</li>
|
||||||
|
|
|
||||||
|
|
@ -21,15 +21,19 @@
|
||||||
{# Insert info about when the sidebar trees were updated last time, so the sidebar_tree_controller can decide if it needs to reload the tree #}
|
{# Insert info about when the sidebar trees were updated last time, so the sidebar_tree_controller can decide if it needs to reload the tree #}
|
||||||
<span id="sidebar-last-time-updated" style="display: none;" data-last-update="{{ sidebar_tree_updater.lastTreeUpdate.format("Y-m-d\\TH:i:sP") }}"></span>
|
<span id="sidebar-last-time-updated" style="display: none;" data-last-update="{{ sidebar_tree_updater.lastTreeUpdate.format("Y-m-d\\TH:i:sP") }}"></span>
|
||||||
|
|
||||||
<div class="d-none" {{ stimulus_controller('turbo/locale_menu') }}>
|
<turbo-stream action="update" target="locale-select-menu">
|
||||||
{% set locales = settings_instance('localization').languageMenuEntries %}
|
<template>
|
||||||
{% if locales is empty %}
|
{% set locales = settings_instance('localization').languageMenuEntries %}
|
||||||
{% set locales = locale_menu %}
|
{% if locales is empty %}
|
||||||
{% endif %}
|
{% set locales = locale_menu %}
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
{% for locale in locales %}
|
||||||
|
<a class="dropdown-item" data-turbo="false" data-turbo-frame="_top" href="{{ path(app.request.attributes.get('_route'),
|
||||||
|
app.request.query.all|merge(app.request.attributes.get('_route_params'))|merge({'_locale': locale})) }}">
|
||||||
|
{{ locale|language_name }} ({{ locale|upper }})</a>
|
||||||
|
{% endfor %}
|
||||||
|
</template>
|
||||||
|
</turbo-stream>
|
||||||
|
|
||||||
|
|
||||||
{% for locale in locales %}
|
|
||||||
<a class="dropdown-item" data-turbo="false" data-turbo-frame="_top" href="{{ path(app.request.attributes.get('_route'),
|
|
||||||
app.request.query.all|merge(app.request.attributes.get('_route_params'))|merge({'_locale': locale})) }}">
|
|
||||||
{{ locale|language_name }} ({{ locale|upper }})</a>
|
|
||||||
{% endfor %}
|
|
||||||
</div>
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue