Small fixes
This commit is contained in:
parent
bb03d4bc14
commit
5e74ab8322
6 changed files with 201 additions and 85 deletions
|
|
@ -1,36 +1,27 @@
|
|||
const API_BASE = window.location.origin;
|
||||
|
||||
// Initialize
|
||||
document.addEventListener("DOMContentLoaded", function () {
|
||||
loadQuestions();
|
||||
loadImages();
|
||||
|
||||
// Set up event listeners
|
||||
setupEventListeners();
|
||||
});
|
||||
|
||||
function setupEventListeners() {
|
||||
// Tab switching
|
||||
document.querySelectorAll('.tab[data-tab]').forEach(tab => {
|
||||
tab.addEventListener('click', (e) => {
|
||||
switchTab(e.target.dataset.tab);
|
||||
});
|
||||
});
|
||||
|
||||
// Add question button
|
||||
|
||||
document.getElementById('addQuestionBtn').addEventListener('click', showAddQuestionModal);
|
||||
|
||||
// Image upload
|
||||
|
||||
document.getElementById('imageUpload').addEventListener('change', uploadImage);
|
||||
|
||||
// Modal close buttons
|
||||
|
||||
document.getElementById('closeModalBtn').addEventListener('click', closeModal);
|
||||
document.getElementById('cancelBtn').addEventListener('click', closeModal);
|
||||
|
||||
// Question form submit
|
||||
|
||||
document.getElementById('questionForm').addEventListener('submit', saveQuestion);
|
||||
|
||||
// Close modal when clicking outside
|
||||
|
||||
document.getElementById('questionModal').addEventListener('click', (e) => {
|
||||
if (e.target.id === 'questionModal') {
|
||||
closeModal();
|
||||
|
|
@ -38,7 +29,6 @@ function setupEventListeners() {
|
|||
});
|
||||
}
|
||||
|
||||
// Tab switching
|
||||
function switchTab(tabName) {
|
||||
document
|
||||
.querySelectorAll(".tab-content")
|
||||
|
|
@ -53,7 +43,6 @@ function switchTab(tabName) {
|
|||
if (tabName === "images") loadImages();
|
||||
}
|
||||
|
||||
// Questions management
|
||||
async function loadQuestions() {
|
||||
try {
|
||||
const response = await fetch(`${API_BASE}/api/admin/questions`);
|
||||
|
|
@ -65,7 +54,7 @@ async function loadQuestions() {
|
|||
}
|
||||
} catch (error) {
|
||||
document.getElementById("questionsList").innerHTML =
|
||||
'<div class="alert alert-danger">Hiba a kérdések betöltésekor</div>';
|
||||
`<div class="alert alert-danger">Hiba a kérdések betöltésekor ${error.message}</div>`;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
@ -77,14 +66,12 @@ function displayQuestions(questions) {
|
|||
<div class="question-item">
|
||||
<h4>ID: ${q.id} - ${q.source}</h4>
|
||||
<p><strong>Kérdés:</strong> ${q.description.substring(
|
||||
0,
|
||||
100
|
||||
)}...</p>
|
||||
<p><strong>Típus:</strong> ${
|
||||
q.type
|
||||
} | <strong>Helyes válasz:</strong> ${
|
||||
["A", "B", "C", "D"][q.correct - 1]
|
||||
}</p>
|
||||
0,
|
||||
100
|
||||
)}...</p>
|
||||
<p><strong>Típus:</strong> ${q.type
|
||||
} | <strong>Helyes válasz:</strong> ${["A", "B", "C", "D"][q.correct - 1]
|
||||
}</p>
|
||||
<div class="question-actions">
|
||||
<button data-edit-id="${q.id}">Szerkesztés</button>
|
||||
<button class="danger" data-delete-id="${q.id}">Törlés</button>
|
||||
|
|
@ -93,14 +80,13 @@ function displayQuestions(questions) {
|
|||
`
|
||||
)
|
||||
.join("");
|
||||
|
||||
// Add event listeners for edit and delete buttons
|
||||
|
||||
container.querySelectorAll('[data-edit-id]').forEach(btn => {
|
||||
btn.addEventListener('click', (e) => {
|
||||
editQuestion(parseInt(e.target.dataset.editId));
|
||||
});
|
||||
});
|
||||
|
||||
|
||||
container.querySelectorAll('[data-delete-id]').forEach(btn => {
|
||||
btn.addEventListener('click', (e) => {
|
||||
deleteQuestion(parseInt(e.target.dataset.deleteId));
|
||||
|
|
@ -213,7 +199,6 @@ async function deleteQuestion(id) {
|
|||
}
|
||||
}
|
||||
|
||||
// Images management
|
||||
async function loadImages() {
|
||||
try {
|
||||
const response = await fetch(`${API_BASE}/api/images`);
|
||||
|
|
@ -242,8 +227,7 @@ function displayImages(images) {
|
|||
`
|
||||
)
|
||||
.join("");
|
||||
|
||||
// Add event listeners for delete buttons
|
||||
|
||||
container.querySelectorAll('[data-delete-image]').forEach(btn => {
|
||||
btn.addEventListener('click', (e) => {
|
||||
deleteImage(e.target.dataset.deleteImage);
|
||||
|
|
@ -279,7 +263,7 @@ async function uploadImage() {
|
|||
);
|
||||
}
|
||||
} catch (error) {
|
||||
showAlert("imagesAlert", "Kapcsolat hiba", "danger");
|
||||
showAlert("imagesAlert", `Kapcsolat hiba: ${error.message}`, "danger");
|
||||
}
|
||||
}
|
||||
|
||||
|
|
@ -301,11 +285,10 @@ async function deleteImage(filename) {
|
|||
throw new Error("Delete failed");
|
||||
}
|
||||
} catch (error) {
|
||||
showAlert("imagesAlert", "Hiba a törlés során", "danger");
|
||||
showAlert("imagesAlert", `Hiba a törlés során: ${error.message}`, "danger");
|
||||
}
|
||||
}
|
||||
|
||||
// Utility functions
|
||||
function closeModal() {
|
||||
document.getElementById("questionModal").style.display = "none";
|
||||
}
|
||||
|
|
@ -319,6 +302,4 @@ function showAlert(elementId, message, type) {
|
|||
setTimeout(() => {
|
||||
alertDiv.style.display = "none";
|
||||
}, 5000);
|
||||
}
|
||||
|
||||
// This is now handled in setupEventListeners()
|
||||
}
|
||||
|
|
@ -338,9 +338,24 @@
|
|||
<div class="form-group">
|
||||
<label for="questionType">Típus:</label>
|
||||
<select id="questionType" required>
|
||||
<option value="mec">Mechanika</option>
|
||||
<option value="mk">Kinematika</option>
|
||||
<option value="md">Dinamika</option>
|
||||
<option value="me">Mechanika</option>
|
||||
<option value="mf">Folyadékok</option>
|
||||
<option value="me">Munka és energia</option>
|
||||
<option value="mf">Folyadékok és gázok mechanikája</option>
|
||||
<option value="mr">Rezgések és hullámok</option>
|
||||
<option value="h">Hőtan</option>
|
||||
<option value="ele">Elektromosság</option>
|
||||
<option value="es">Elektrosztatika</option>
|
||||
<option value="ee">Egyenáram</option>
|
||||
<option value="ev">Váltakozó áram</option>
|
||||
<option value="m">Mágnesesség</option>
|
||||
<option value="o">Fénytan</option>
|
||||
<option value="atm">Atomfizika</option>
|
||||
<option value="ah">Atomhéj</option>
|
||||
<option value="am">Atommag</option>
|
||||
<option value="cs">Égi mechanika, csillagászat</option>
|
||||
<option value="v">Vegyes</option>
|
||||
</select>
|
||||
</div>
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue