Frontend v1.3.1

Fix aplicado:

Ahora cuando envías una imagen en el chat:

Se sube al servidor (S3)
El servidor devuelve la URL permanente en attached_files
El frontend actualiza el mensaje del usuario reemplazando la blob URL con la URL de S3
Se libera la blob URL antigua para evitar memory leaks
This commit is contained in:
2025-12-05 05:38:05 -03:00
parent ae3a50054a
commit 6455d351dd
4 changed files with 31 additions and 5 deletions

View File

@@ -1,7 +1,7 @@
{ {
"name": "checklist-frontend", "name": "checklist-frontend",
"private": true, "private": true,
"version": "1.3.0", "version": "1.3.2",
"type": "module", "type": "module",
"scripts": { "scripts": {
"dev": "vite", "dev": "vite",

View File

@@ -1,6 +1,6 @@
// Service Worker para PWA con detección de actualizaciones // Service Worker para PWA con detección de actualizaciones
// IMPORTANTE: Actualizar esta versión cada vez que se despliegue una nueva versión // IMPORTANTE: Actualizar esta versión cada vez que se despliegue una nueva versión
const CACHE_NAME = 'ayutec-v1.3.0'; const CACHE_NAME = 'ayutec-v1.3.2';
const urlsToCache = [ const urlsToCache = [
'/', '/',
'/index.html' '/index.html'

View File

@@ -5206,8 +5206,8 @@ function InspectionModal({ checklist, existingInspection, user, onClose, onCompl
</div> </div>
)} )}
{/* Photos */} {/* Photos - Solo mostrar si NO es 'none' */}
{(currentQuestion.photo_requirement !== 'none' || currentQuestion.allow_photos) && ( {currentQuestion.photo_requirement !== 'none' && (
<div> <div>
<label className="block text-sm font-medium text-gray-700 mb-2"> <label className="block text-sm font-medium text-gray-700 mb-2">
Fotografías / Documentos Fotografías / Documentos
@@ -5713,6 +5713,32 @@ function AIAssistantChatModal({ question, inspection, allAnswers, messages, setM
const data = await response.json() const data = await response.json()
console.log('📥 Respuesta de IA:', data) console.log('📥 Respuesta de IA:', data)
// Actualizar el mensaje del usuario con las URLs reales de S3
if (data.attached_files && data.attached_files.length > 0) {
setMessages(prev => {
const updated = [...prev]
const lastUserMsgIndex = updated.length - 1
if (updated[lastUserMsgIndex].role === 'user' && updated[lastUserMsgIndex].files) {
// Reemplazar blob URLs con URLs de S3
updated[lastUserMsgIndex].files = updated[lastUserMsgIndex].files.map((file, idx) => {
const serverFile = data.attached_files[idx]
if (serverFile?.url) {
// Liberar blob URL anterior
if (file.preview) {
URL.revokeObjectURL(file.preview)
}
return {
...file,
preview: serverFile.url // Ahora es URL de S3
}
}
return file
})
}
return updated
})
}
// Crear mensaje del asistente con archivos adjuntos (usando URLs del servidor) // Crear mensaje del asistente con archivos adjuntos (usando URLs del servidor)
const assistantMessage = { const assistantMessage = {
role: 'assistant', role: 'assistant',

View File

@@ -153,7 +153,7 @@ export default function Sidebar({ user, activeTab, setActiveTab, sidebarOpen, se
className="w-10 h-10 object-contain bg-white rounded p-1" className="w-10 h-10 object-contain bg-white rounded p-1"
/> />
<p className="text-xs text-indigo-300 font-medium hover:text-indigo-200"> <p className="text-xs text-indigo-300 font-medium hover:text-indigo-200">
Ayutec v1.3.0 Ayutec v1.3.2
</p> </p>
</a> </a>
</div> </div>