48 lines
1.7 KiB
TypeScript
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]),
|
|
}));
|
|
}
|
|
};
|