1
0
mirror of https://github.com/mailcow/mailcow-dockerized.git synced 2024-12-21 01:49:22 +02:00

[Web] Do not show Apps dropdown, when there is only single item

Signed-off-by: Kristian Feldsam <feldsam@gmail.com>
This commit is contained in:
Kristian Feldsam 2024-08-20 11:47:51 +02:00
parent f9a7712025
commit 22e757ac36

View File

@ -89,24 +89,33 @@
</ul> </ul>
</li> </li>
{% endif %} {% endif %}
{% if mailcow_apps or app_links %} {% if mailcow_apps|length == 1 and not app_links %}
<li class="nav-item dropdown"> {% set app = mailcow_apps[0] %}
<a href="#" class="nav-link dropdown-toggle" data-bs-toggle="dropdown" role="button" aria-expanded="false"><i class="bi bi-link-45deg me-2"></i> {{ ui_texts.apps_name|raw }}</a> {% if not skip_sogo or not is_uri('SOGo', app.link) %}
<ul class="dropdown-menu"> <li class="nav-item"{% if app.description %} title="{{ app.description }}"{% endif %}>
{% for app in mailcow_apps %} <a href="{{ app.link }}" class="nav-link">{{ app.name }}</a>
{% if not skip_sogo or not is_uri('SOGo', app.link) %} </li>
<li {% if app.description %}title="{{ app.description }}"{% endif %}> {% endif %}
<a href="{{ app.link }}" class="dropdown-item">{{ app.name }}</a> {% else %}
</li> {% if mailcow_apps or app_links %}
{% endif %} <li class="nav-item dropdown">
{% endfor %} <a href="#" class="nav-link dropdown-toggle" data-bs-toggle="dropdown" role="button" aria-expanded="false"><i class="bi bi-link-45deg me-2"></i> {{ ui_texts.apps_name|raw }}</a>
{% for row in app_links %} <ul class="dropdown-menu">
{% for key, val in row %} {% for app in mailcow_apps %}
<li><a href="{{ val }}" class="dropdown-item">{{ key }}</a></li> {% if not skip_sogo or not is_uri('SOGo', app.link) %}
<li {% if app.description %}title="{{ app.description }}"{% endif %}>
<a href="{{ app.link }}" class="dropdown-item">{{ app.name }}</a>
</li>
{% endif %}
{% endfor %} {% endfor %}
{% endfor %} {% for row in app_links %}
</ul> {% for key, val in row %}
</li> <li><a href="{{ val }}" class="dropdown-item">{{ key }}</a></li>
{% endfor %}
{% endfor %}
</ul>
</li>
{% endif %}
{% endif %} {% endif %}
{% if not dual_login and mailcow_cc_username %} {% if not dual_login and mailcow_cc_username %}
<li class="logged-in-as nav-item"><a href="#" onclick="logout.submit()" class="nav-link"><b class="username-lia">{{ mailcow_cc_username }}</b> <i class="bi bi-power ms-2"></i></a></li> <li class="logged-in-as nav-item"><a href="#" onclick="logout.submit()" class="nav-link"><b class="username-lia">{{ mailcow_cc_username }}</b> <i class="bi bi-power ms-2"></i></a></li>
@ -235,7 +244,7 @@ function recursiveBase64StrToArrayBuffer(obj) {
$(".totp-authenticator-selection").click(function(){ $(".totp-authenticator-selection").click(function(){
$(".totp-authenticator-selection").removeClass("active"); $(".totp-authenticator-selection").removeClass("active");
$(this).addClass("active"); $(this).addClass("active");
var id = $(this).children('input').first().val(); var id = $(this).children('input').first().val();
$("#totp_selected_id").val(id); $("#totp_selected_id").val(id);
@ -244,7 +253,7 @@ function recursiveBase64StrToArrayBuffer(obj) {
if ($('.totp-authenticator-selection').length == 1 && if ($('.totp-authenticator-selection').length == 1 &&
$('#pending_tfa_tab_yubi_otp').length == 0 && $('#pending_tfa_tab_yubi_otp').length == 0 &&
$('.webauthn-authenticator-selection').length == 0){ $('.webauthn-authenticator-selection').length == 0){
// select default if only one authenticator exists // select default if only one authenticator exists
$('.totp-authenticator-selection').addClass("active"); $('.totp-authenticator-selection').addClass("active");
@ -257,7 +266,7 @@ function recursiveBase64StrToArrayBuffer(obj) {
$('#pending_tfa_tab_totp').on('shown.bs.tab', function() { $('#pending_tfa_tab_totp').on('shown.bs.tab', function() {
// autofocus // autofocus
setTimeout(function() { $("#collapseTotpTFA").find('input[name="token"]').focus(); }, 200); setTimeout(function() { $("#collapseTotpTFA").find('input[name="token"]').focus(); }, 200);
}); });
// validate Yubi OTP tfa // validate Yubi OTP tfa
if ($('.webauthn-authenticator-selection').length == 0){ if ($('.webauthn-authenticator-selection').length == 0){
// autofocus // autofocus
@ -276,10 +285,10 @@ function recursiveBase64StrToArrayBuffer(obj) {
$(".webauthn-authenticator-selection").click(function(){ $(".webauthn-authenticator-selection").click(function(){
$(".webauthn-authenticator-selection").removeClass("active"); $(".webauthn-authenticator-selection").removeClass("active");
$(this).addClass("active"); $(this).addClass("active");
var id = $(this).children('input').first().val(); var id = $(this).children('input').first().val();
$("#webauthn_selected_id").val(id); $("#webauthn_selected_id").val(id);
var webauthn_status_auth = document.getElementById('webauthn_status_auth'); var webauthn_status_auth = document.getElementById('webauthn_status_auth');
webauthn_status_auth.style.setProperty('display', 'flex', 'important'); webauthn_status_auth.style.setProperty('display', 'flex', 'important');
var webauthn_return_code = document.getElementById('webauthn_return_code'); var webauthn_return_code = document.getElementById('webauthn_return_code');
@ -302,7 +311,7 @@ function recursiveBase64StrToArrayBuffer(obj) {
console.log(json); console.log(json);
if (json.success === false) throw new Error(); if (json.success === false) throw new Error();
if (json.type === "error") throw new Error(json.msg); if (json.type === "error") throw new Error(json.msg);
recursiveBase64StrToArrayBuffer(json); recursiveBase64StrToArrayBuffer(json);
return json; return json;
}).then(getCredentialArgs => { }).then(getCredentialArgs => {
@ -329,7 +338,7 @@ function recursiveBase64StrToArrayBuffer(obj) {
webauthn_return_code.style.setProperty('display', 'block', 'important'); webauthn_return_code.style.setProperty('display', 'block', 'important');
webauthn_return_code.innerHTML = lang_tfa.error_code + ': ' + err + ' ' + lang_tfa.reload_retry; webauthn_return_code.innerHTML = lang_tfa.error_code + ': ' + err + ' ' + lang_tfa.reload_retry;
}); });
} }
}); });
$('#ConfirmTFAModal').on('hidden.bs.modal', function(){ $('#ConfirmTFAModal').on('hidden.bs.modal', function(){
// cancel pending login // cancel pending login