public/faq.html aktualisiert

This commit is contained in:
M_Viper 2024-10-18 23:52:24 +00:00
parent e8928f2b75
commit 9ddafba151
1 changed files with 63 additions and 134 deletions

View File

@ -7,7 +7,7 @@
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0-beta3/css/all.min.css">
<link rel="icon" type="image/png" href="img/Viper-plex-logo.png">
<title>Viper-Plex FAQs</title>
<title id="web-title">${WEB_NAME}</title> <!-- Platzhalter für den Titel -->
</head>
<body>
@ -17,7 +17,7 @@
</a>
</div>
<div class="welcome-box">
<h1>Viper-Plex FAQs</h1>
<h1 id="welcome-title">Willkommen bei ${WEB_NAME}</h1> <!-- ID für das h1-Tag -->
<nav class="navbar">
<div class="navbar-container">
<a href="index.html" class="navbar-link">Home</a>
@ -55,80 +55,9 @@
</div>
<footer class="footer">
<p>&copy; 2024 Viper-Plex. Alle Rechte vorbehalten.</p>
<p>&copy; 2024 M_Viper. Alle Rechte vorbehalten.</p>
</footer>
<script src="js/script.js"></script>
<script>
// Funktion zum Abrufen der FAQs
function fetchFaqs() {
fetch('/api/faqs')
.then(response => response.json())
.then(data => {
const faqSection = document.getElementById('faq-section');
faqSection.innerHTML = ''; // Leere den Inhalt zuerst
if (data.length === 0) {
faqSection.innerHTML = '<p><h3>Es gibt derzeit keine FAQs.</h3></p>';
} else {
data.forEach((faq, index) => {
const faqItem = document.createElement('div');
faqItem.classList.add('faq-item');
const faqToggle = document.createElement('div');
faqToggle.classList.add('faq-toggle');
faqToggle.innerHTML = `<h3 class="faq-question">${index + 1}. ${faq.question}</h3>
<i class="fas fa-chevron-down arrow"></i>`;
faqItem.appendChild(faqToggle);
const faqAnswer = document.createElement('p');
faqAnswer.classList.add('faq-answer');
faqAnswer.innerText = faq.answer;
faqItem.appendChild(faqAnswer);
// Event-Listener hinzufügen, um die Antwort anzuzeigen oder auszublenden
faqToggle.addEventListener('click', () => {
faqAnswer.classList.toggle('show');
const arrow = faqToggle.querySelector('.arrow');
arrow.style.transform = faqAnswer.classList.contains('show') ? 'rotate(180deg)' : 'rotate(0deg)';
});
faqSection.appendChild(faqItem);
});
}
})
.catch(error => console.error('Fehler beim Abrufen der FAQs:', error));
}
document.addEventListener('DOMContentLoaded', () => {
// FAQs beim Laden der Seite abrufen
fetchFaqs();
// Darkmode umschalten
const toggle = document.getElementById('dark-mode-toggle');
// Darkmode-Zustand beim Laden der Seite überprüfen und anwenden
const darkModeEnabled = localStorage.getItem('darkMode') === 'true';
toggle.checked = darkModeEnabled;
if (darkModeEnabled) {
document.body.classList.add('dark-mode');
}
toggle.addEventListener('change', () => {
const isChecked = toggle.checked;
document.body.classList.toggle('dark-mode', isChecked);
// Speichere den Zustand in localStorage
localStorage.setItem('darkMode', isChecked);
});
// Version abrufen
fetch('/api/bot-version')
.then(response => response.json())
.then(data => {
const botVersion = document.getElementById('bot-version');
botVersion.textContent = data.version; // Setze die Versionsnummer
})
.catch(error => console.error('Fehler beim Abrufen der Bot-Version:', error));
});
</script>
</body>
</html>