document.addEventListener('DOMContentLoaded', function () { const fileUploadInput = document.getElementById('document-upload'); const fileUploadLabel = document.querySelector('.custom-file-upload'); const fileNameDisplay = document.getElementById('file-upload-filename'); const translateBtn = document.getElementById('translate-btn'); const processingMessage = document.getElementById('processing-message'); // Trigger file input click when the custom upload area is clicked if(fileUploadLabel) { fileUploadLabel.addEventListener('click', () => { if(fileUploadInput) { fileUploadInput.click(); } }); } // Update UI when a file is selected if(fileUploadInput) { fileUploadInput.addEventListener('change', () => { if (fileUploadInput.files.length > 0) { const fileName = fileUploadInput.files[0].name; if(fileNameDisplay) { fileNameDisplay.textContent = `Selected file: ${fileName}`; } if(translateBtn) { translateBtn.disabled = false; } } else { if(fileNameDisplay) { fileNameDisplay.textContent = ''; } if(translateBtn) { translateBtn.disabled = true; } } }); } // Handle form submission const translationForm = document.getElementById('translation-form'); if(translationForm) { translationForm.addEventListener('submit', function(e) { e.preventDefault(); const formData = new FormData(); formData.append('document', fileUploadInput.files[0]); formData.append('source-lang', document.getElementById('source-lang').value); formData.append('target-lang', document.getElementById('target-lang').value); const responseMessageDiv = document.getElementById('response-message'); if(processingMessage) { processingMessage.style.display = 'block'; } if(responseMessageDiv){ responseMessageDiv.innerHTML = ''; responseMessageDiv.style.display = 'none'; } if(translateBtn) { translateBtn.disabled = true; translateBtn.innerHTML = ' Translating...'; } fetch('upload.php', { method: 'POST', body: formData }) .then(response => { if (!response.ok) { // Try to get error message from JSON response, otherwise use status text return response.json().then(err => { throw new Error(err.message || response.statusText); }).catch(() => { throw new Error(response.statusText); }); } return response.json(); }) .then(data => { processingMessage.style.display = 'none'; if (data.status === 'success') { const translatedText = data.data.translatedText; const outputContainer = document.getElementById('translation-output-container'); const outputElement = document.getElementById('translation-output'); if (outputElement && outputContainer) { outputElement.textContent = translatedText; outputContainer.style.display = 'block'; } responseMessageDiv.innerHTML = `