diff --git a/server.js b/server.js index 6fad6c7..e669d93 100644 --- a/server.js +++ b/server.js @@ -540,14 +540,45 @@ app.post("/providers/import/:id", authMiddleware, async (req, res) => { app.put('/providers/scraped/:id', authMiddleware, async (req, res) => { const { id } = req.params; - const { name, phone, address, cp, description, guild_id, assigned_to, internal_notes, client_notes, is_urgent } = req.body; + const { name, phone, address, cp, description, guild_id, assigned_to, internal_notes, client_notes, is_urgent, automation_status } = req.body; + try { + // Si solo enviamos el cambio de estado de automatización (desde la papelera) + if (automation_status) { + await pool.query( + `UPDATE scraped_services SET automation_status = $1 WHERE id = $2 AND owner_id = $3`, + [automation_status, id, req.user.accountId] + ); + return res.json({ ok: true }); + } + + // Si es una edición completa de datos (desde el botón modificar) const current = await pool.query('SELECT raw_data FROM scraped_services WHERE id = $1 AND owner_id = $2', [id, req.user.accountId]); if (current.rows.length === 0) return res.status(404).json({ error: 'No encontrado' }); - const updatedRawData = { ...current.rows[0].raw_data, "Nombre Cliente": name, "Teléfono": phone, "Dirección": address, "Código Postal": cp, "Descripción": description, "Urgente": is_urgent ? "Sí" : "No", "guild_id": guild_id, "assigned_to": assigned_to, "internal_notes": internal_notes, "client_notes": client_notes }; - await pool.query(`UPDATE scraped_services SET raw_data = $1, status = 'pending' WHERE id = $2 AND owner_id = $3`, [JSON.stringify(updatedRawData), id, req.user.accountId]); + + const updatedRawData = { + ...current.rows[0].raw_data, + "Nombre Cliente": name, + "Teléfono": phone, + "Dirección": address, + "Código Postal": cp, + "Descripción": description, + "Urgente": is_urgent ? "Sí" : "No", + "guild_id": guild_id, + "assigned_to": assigned_to, + "internal_notes": internal_notes, + "client_notes": client_notes + }; + + await pool.query( + `UPDATE scraped_services SET raw_data = $1, status = 'pending' WHERE id = $2 AND owner_id = $3`, + [JSON.stringify(updatedRawData), id, req.user.accountId] + ); res.json({ ok: true }); - } catch (error) { res.status(500).json({ error: 'Error' }); } + } catch (error) { + console.error(error); + res.status(500).json({ error: 'Error al actualizar' }); + } }); app.get("/discovery/keys/:provider", authMiddleware, async (req, res) => {