diff --git a/servicios.html b/servicios.html
index 36f75ea..7417ea3 100644
--- a/servicios.html
+++ b/servicios.html
@@ -375,40 +375,44 @@
// ==========================================
function getServiceStateInfo(s) {
const raw = s.raw_data || {};
- const dbStat = raw.status_operativo; // Aquí viene el ID del estado (ej: "42") o texto antiguo
+ const dbStat = raw.status_operativo; // Aquí viene el ID del estado o texto antiguo
// 1. Prioridad Máxima: Bolsa de Trabajo / Robot WhatsApp
if (!s.assigned_name && (s.automation_status === 'in_progress' || s.automation_status === 'failed')) {
return { id: 'bolsa', name: s.automation_status === 'in_progress' ? 'Buscando Operario' : 'Fallo en Bolsa', color: s.automation_status === 'in_progress' ? 'amber' : 'red', isBlocked: true, is_final: false };
}
- // 2. Match Directo por ID (La forma más segura para que los filtros de los botones no fallen)
- // Si dbStat es un ID que existe en nuestra lista de estados, lo usamos directamente.
- const foundById = systemStatuses.find(st => String(st.id) === String(dbStat));
- if (foundById) return { ...foundById, isBlocked: false };
-
- // 3. Lógica de "La pelota en el tejado": Si tiene operario pero NO tiene fecha agendada
- if (s.assigned_name && (!raw.scheduled_date || raw.scheduled_date === "")) {
- const asignado = systemStatuses.find(st => st.name.toLowerCase() === 'asignado');
- const esperando = systemStatuses.find(st => st.name.toLowerCase().includes('esperando'));
-
- // Si en la base de datos el texto coincide con "esperando" (compatibilidad)
- if (dbStat === 'esperando_cliente' && esperando) return { ...esperando, isBlocked: false };
-
- // Por defecto, si tiene técnico asignado pero no hay fecha ni estado específico de "esperando",
- // lo mandamos a la columna "ASIGNADO" (Oficina debe gestionar).
- if (asignado) return { ...asignado, isBlocked: false };
- }
-
- // 4. Si viene nuevo del scraper (Sin operario y sin estado)
- if (!s.assigned_name || dbStat === 'sin_asignar') {
+ // 2. Si viene limpio del scraper sin estado -> Pendiente de Asignar
+ if (!s.assigned_name && (!dbStat || dbStat === 'sin_asignar')) {
const found = systemStatuses.find(st => st.name.toLowerCase().includes('pendiente de asignar')) || systemStatuses[0];
return { ...found, isBlocked: false };
}
+ // 3. Match Directo por ID (Si ya se guardó con el nuevo sistema de IDs numéricos)
+ const foundById = systemStatuses.find(st => String(st.id) === String(dbStat));
+ if (foundById) return { ...foundById, isBlocked: false };
+
+ // 4. Lógica de "Asignado" vs "Esperando Cliente" (Si tiene operario pero NO fecha)
+ if (s.assigned_name && (!raw.scheduled_date || raw.scheduled_date === "")) {
+ const asignado = systemStatuses.find(st => st.name.toLowerCase() === 'asignado');
+ const esperando = systemStatuses.find(st => st.name.toLowerCase().includes('esperando'));
+
+ // Si en BD es el texto antiguo 'esperando_cliente'
+ if (dbStat === 'esperando_cliente' && esperando) return { ...esperando, isBlocked: false };
+
+ // Si es el texto antiguo 'asignado_operario' o no tiene estado definido pero sí tiene operario
+ if ((dbStat === 'asignado_operario' || !dbStat) && asignado) return { ...asignado, isBlocked: false };
+
+ // Fallback por defecto si no encaja en lo anterior
+ if (asignado) return { ...asignado, isBlocked: false };
+ }
+
// 5. Fallbacks históricos de texto (Para que los servicios antiguos no se rompan)
const stLower = String(dbStat).toLowerCase();
- if (stLower === 'citado') return { ...systemStatuses.find(st => st.name.toLowerCase().includes('citado')), isBlocked: false };
+ if (stLower === 'citado' || (s.assigned_name && raw.scheduled_date && !dbStat)) {
+ const citado = systemStatuses.find(st => st.name.toLowerCase().includes('citado'));
+ if(citado) return { ...citado, isBlocked: false };
+ }
if (stLower === 'de_camino') return { ...systemStatuses.find(st => st.name.toLowerCase().includes('camino')), isBlocked: false };
if (stLower === 'trabajando') return { ...systemStatuses.find(st => st.name.toLowerCase().includes('trabajando')), isBlocked: false };
if (stLower === 'incidencia') return { ...systemStatuses.find(st => st.name.toLowerCase().includes('incidencia')), isBlocked: false };