Files
CPLv4.0/services/fetchAnalogInputsService.ts
2025-06-19 12:27:00 +02:00

48 lines
1.7 KiB
TypeScript

// services/fetchAnalogInputsService.ts
export const fetchAnalogInputsService = async () => {
const mode = process.env.NEXT_PUBLIC_CPL_MODE;
if (mode === "production") {
const scriptUrl = "/CPL?/CPL/SERVICE/analogInputs.js";
await new Promise<void>((resolve, reject) => {
const script = document.createElement("script");
script.src = scriptUrl;
script.async = true;
script.onload = () => resolve();
script.onerror = () => reject("❌ Fehler beim Laden der analogInputs.js");
document.body.appendChild(script);
});
const win = window as any;
return Array.from({ length: 8 }, (_, i) => ({
id: i + 1,
value: parseFloat(win.win_analogInputsValues[i]),
label: win.win_analogInputsNames[i],
unit: win.win_analogInputsUnits[i],
offset: parseFloat(win.win_analogInputsOffset[i]),
factor: parseFloat(win.win_analogInputsFactor[i]),
interval: parseInt(win.win_analogInputsloggerIntervall[i]),
weighting: parseInt(win.win_analogInputsWeighting[i]),
}));
} else {
const res = await fetch("/api/cpl/getAnalogInputsHandler");
if (!res.ok) throw new Error("❌ Fehler beim Laden der analogen Eingänge");
const data = await res.json();
return data.win_analogInputsValues.map((value: number, i: number) => ({
id: i + 1,
value,
label: data.win_analogInputsNames[i],
unit: data.win_analogInputsUnits[i],
offset: parseFloat(data.win_analogInputsOffset[i]),
factor: parseFloat(data.win_analogInputsFactor[i]),
interval: parseInt(data.win_analogInputsloggerIntervall[i]),
weighting: parseInt(data.win_analogInputsWeighting[i]),
}));
}
};