// wwwroot/js/converters/image-ocr-converter.js // Implementação específica para conversor de imagem para texto (OCR) async function performConversion(formData) { const fileInput = formData.get('file'); if (!fileInput || fileInput.size === 0) { throw new Error('Por favor, selecione uma imagem'); } // Validar tipo de arquivo const allowedTypes = ['image/jpeg', 'image/jpg', 'image/png', 'image/gif', 'image/bmp', 'application/pdf']; if (!allowedTypes.includes(fileInput.type)) { throw new Error('Formato de arquivo não suportado. Use JPG, PNG, GIF, BMP ou PDF.'); } // Validar tamanho (15MB) if (fileInput.size > 15 * 1024 * 1024) { throw new Error('Arquivo muito grande. Tamanho máximo: 15MB'); } const requestData = new FormData(); requestData.append('inputType', 'file'); requestData.append('fileInput', fileInput); requestData.append('language', document.documentElement.lang || 'pt'); // Adicionar opções de OCR se houver const ocrLanguage = formData.get('ocrLanguage') || 'por'; const options = { ocrLanguage: ocrLanguage }; requestData.append('options', JSON.stringify(options)); const response = await fetch('/converter/api/convert/image-ocr', { method: 'POST', body: requestData }); if (!response.ok) { const error = await response.json(); throw new Error(error.message || 'Erro no processamento da imagem'); } const result = await response.json(); // Mostrar resultado do OCR showOcrResult(result.outputText, fileInput); } function showOcrResult(extractedText, originalFile) { const outputTextElement = document.getElementById('outputText'); const successActions = document.getElementById('successActions'); if (outputTextElement) { outputTextElement.value = extractedText; document.getElementById('outputArea').style.display = 'block'; successActions.style.display = 'block'; // Mostrar preview da imagem showImagePreview(originalFile); // Adicionar botão para salvar texto addSaveTextButton(extractedText); } } function showImagePreview(file) { const previewContainer = document.getElementById('imagePreview'); if (previewContainer && file.type.startsWith('image/')) { const reader = new FileReader(); reader.onload = function (e) { previewContainer.innerHTML = `