Solved bugs

This commit is contained in:
Kevin Veen-Birkenbach 2025-01-09 15:34:32 +01:00
parent f85dc5bb18
commit e303968ca5
3 changed files with 39 additions and 5 deletions
app
config.yaml
static/js
templates/moduls

@ -193,7 +193,7 @@ navigation:
identifier: "+491781798023" identifier: "+491781798023"
warning: Signal is not hosted by me! warning: Signal is not hosted by me!
alternatives: alternatives:
link: navigation.header.contact.matrix - link: navigation.header.contact.matrix
- name: Telegram - name: Telegram
description: Message me on Telegram description: Message me on Telegram
icon: icon:
@ -203,7 +203,7 @@ navigation:
identifier: kevinveenbirkenbach identifier: kevinveenbirkenbach
warning: Telegram is not hosted by me! warning: Telegram is not hosted by me!
alternatives: alternatives:
link: navigation.header.contact.matrix - link: navigation.header.contact.matrix
- name: WhatsApp - name: WhatsApp
description: Chat with me on WhatsApp description: Chat with me on WhatsApp
icon: icon:
@ -212,7 +212,7 @@ navigation:
identifier: "+491781798023" identifier: "+491781798023"
warning: Whatsapp is not hosted by me! warning: Whatsapp is not hosted by me!
alternatives: alternatives:
link: navigation.header.contact.matrix - link: navigation.header.contact.matrix
footer: footer:
- name: External Accounts - name: External Accounts
description: Me on other plattforms description: Me on other plattforms

@ -3,10 +3,13 @@ function openDynamicPopup(subitem) {
document.getElementById('dynamicModalLabel').innerText = subitem.description; document.getElementById('dynamicModalLabel').innerText = subitem.description;
// Setze den Identifier, falls vorhanden // Setze den Identifier, falls vorhanden
const identifierBox = document.getElementById('dynamicIdentifierBox');
const modalContent = document.getElementById('dynamicModalContent'); const modalContent = document.getElementById('dynamicModalContent');
if (subitem.identifier) { if (subitem.identifier) {
identifierBox.classList.remove('d-none');
modalContent.value = subitem.identifier; modalContent.value = subitem.identifier;
} else { } else {
identifierBox.classList.add('d-none');
modalContent.value = ''; modalContent.value = '';
} }
@ -39,10 +42,34 @@ function openDynamicPopup(subitem) {
linkHref.href = '#'; linkHref.href = '#';
} }
// Konfiguriere die Alternativen
const alternativesList = document.getElementById('dynamicAlternativesList');
alternativesList.innerHTML = ''; // Clear existing alternatives
if (subitem.alternatives && subitem.alternatives.length > 0) {
subitem.alternatives.forEach(alt => {
const listItem = document.createElement('li');
listItem.classList.add('list-group-item', 'd-flex', 'justify-content-between', 'align-items-center');
listItem.innerHTML = `
<span>
<i class="${alt.icon.class}"></i> ${alt.name}
</span>
<button class="btn btn-outline-secondary btn-sm" onclick='openDynamicPopup(${JSON.stringify(alt)})'>Open</button>
`;
alternativesList.appendChild(listItem);
});
} else {
const noAltItem = document.createElement('li');
noAltItem.classList.add('list-group-item');
noAltItem.innerText = 'No alternatives available.';
alternativesList.appendChild(noAltItem);
}
// Kopierfunktion für den Identifier // Kopierfunktion für den Identifier
document.getElementById('dynamicCopyButton').addEventListener('click', function () { document.getElementById('dynamicCopyButton').addEventListener('click', function () {
modalContent.select(); modalContent.select();
navigator.clipboard.writeText(modalContent.value) navigator.clipboard.writeText(modalContent.value).then(() => {
alert('Identifier copied to clipboard!');
});
}); });
// Modal anzeigen // Modal anzeigen

@ -15,7 +15,7 @@
<i class="fa-solid fa-circle-info"></i> <span id="dynamicModalInfoText"></span> <i class="fa-solid fa-circle-info"></i> <span id="dynamicModalInfoText"></span>
</div> </div>
<!-- Eingabebox für Identifier --> <!-- Eingabebox für Identifier -->
<div class="input-group mt-2"> <div id="dynamicIdentifierBox" class="input-group mt-2 d-none">
<input type="text" id="dynamicModalContent" class="form-control" readonly> <input type="text" id="dynamicModalContent" class="form-control" readonly>
<button class="btn btn-outline-secondary" type="button" id="dynamicCopyButton">Copy</button> <button class="btn btn-outline-secondary" type="button" id="dynamicCopyButton">Copy</button>
</div> </div>
@ -23,6 +23,13 @@
<div id="dynamicModalLink" class="mt-3 d-none"> <div id="dynamicModalLink" class="mt-3 d-none">
<a href="#" target="_blank" class="btn btn-primary w-100" id="dynamicModalLinkHref">Open Link</a> <a href="#" target="_blank" class="btn btn-primary w-100" id="dynamicModalLinkHref">Open Link</a>
</div> </div>
<!-- Alternativen, falls vorhanden -->
<div id="dynamicAlternatives" class="mt-4">
<h6>Alternatives:</h6>
<ul class="list-group" id="dynamicAlternativesList">
<li class="list-group-item">No alternatives available.</li>
</ul>
</div>
</div> </div>
<div class="modal-footer"> <div class="modal-footer">
<button type="button" class="btn btn-secondary" data-bs-dismiss="modal">Close</button> <button type="button" class="btn btn-secondary" data-bs-dismiss="modal">Close</button>