You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

58 lines
1.8 KiB
JavaScript

// export-service.js
/**
* Convierte un array de objetos JSON a formato CSV
*/
function convertToCSV(objArray) {
const array = typeof objArray !== 'object' ? JSON.parse(objArray) : objArray;
let str = '';
// Extraer cabeceras (keys del primer objeto)
const headers = Object.keys(array[0]).join(',');
str += headers + '\r\n';
// Rellenar filas
for (let i = 0; i < array.length; i++) {
let line = '';
for (let index in array[i]) {
if (line != '') line += ',';
line += array[i][index];
}
str += line + '\r\n';
}
return str;
}
/**
* Manejador principal del evento click de los botones
*/
async function handleExport(sensorType) {
try {
// 1. Obtener datos (Mock actual, fetch real en el futuro)
const data = await fetchHistoricalData(sensorType);
// 2. Convertir a CSV
const csvText = convertToCSV(data);
// 3. Crear un Blob (Objeto de datos binarios)
const blob = new Blob([csvText], { type: 'text/csv;charset=utf-8;' });
// 4. Crear un enlace temporal para forzar la descarga en la laptop
const link = document.createElement("a");
const url = URL.createObjectURL(blob);
link.setAttribute("href", url);
link.setAttribute("download", `export_${sensorType}_${new Date().getTime()}.csv`);
link.style.visibility = 'hidden';
document.body.appendChild(link);
link.click();
document.body.removeChild(link);
console.log(`[EXITO] Archivo CSV descargado para ${sensorType}`);
} catch (error) {
console.error("[ERROR] Fallo al exportar el CSV:", error);
alert("Hubo un error al generar el archivo. Revisa la consola.");
}
}