- Unterstützung für drei Modi implementiert: json, jsmock und production - fetchDigitalOutputsService.ts erkennt NEXT_PUBLIC_CPL_MODE und lädt Daten je nach Umgebung - API-Handler /api/cpl/updateDigitalOutputsHandler verarbeitet POST-Anfragen für json und jsmock - In production wird Statusänderung per Redirect (window.location.href) an das CPL gesendet - Redux-Slice für digitale Ausgänge vollständig angebunden - UI (DigitalOutputsWidget.tsx) zeigt Status und ermöglicht das Umschalten - Dokumentation als README_digitalOutputs_final.md mit UML-Diagrammen ergänzt - CHANGELOG.md auf Version 1.6.417 aktualisiert
92 lines
2.6 KiB
TypeScript
92 lines
2.6 KiB
TypeScript
// /services/fetchDigitalOutputsService.ts
|
|
|
|
export const fetchDigitalOutputsService = async () => {
|
|
const mode = process.env.NEXT_PUBLIC_CPL_MODE;
|
|
|
|
if (mode === "json") {
|
|
const res = await fetch("/api/cpl/getDigitalOutputsJsonHandler");
|
|
if (!res.ok)
|
|
throw new Error("❌ Fehler beim Laden der digitalen Ausgänge (JSON)");
|
|
|
|
const data = await res.json();
|
|
const state = data.win_da_state;
|
|
const labels = data.win_da_bezeichnung;
|
|
|
|
if (!Array.isArray(state)) {
|
|
console.warn("⚠️ win_da_state fehlt oder ist ungültig in json:", state);
|
|
return [];
|
|
}
|
|
|
|
return state.slice(0, 4).map((status: number, index: number) => ({
|
|
id: index + 1,
|
|
label:
|
|
Array.isArray(labels) && labels[index]
|
|
? labels[index]
|
|
: `Ausgang ${index + 1}`,
|
|
status: status === 1,
|
|
}));
|
|
}
|
|
|
|
if (mode === "jsmock") {
|
|
const res = await fetch(
|
|
"/api/fake-cpl/SERVICE/getDigitalOutputsDeviceMockHandler"
|
|
);
|
|
if (!res.ok)
|
|
throw new Error("❌ Fehler beim Laden der digitalen Ausgänge (jsmock)");
|
|
|
|
const data = await res.json();
|
|
const state = data.win_da_state;
|
|
const labels = data.win_da_bezeichnung;
|
|
|
|
if (!Array.isArray(state)) {
|
|
console.warn("⚠️ win_da_state fehlt oder ist ungültig in jsmock:", state);
|
|
return [];
|
|
}
|
|
|
|
return state.slice(0, 4).map((status: number, index: number) => ({
|
|
id: index + 1,
|
|
label:
|
|
Array.isArray(labels) && labels[index]
|
|
? labels[index]
|
|
: `Ausgang ${index + 1}`,
|
|
status: status === 1,
|
|
}));
|
|
}
|
|
|
|
if (mode === "production") {
|
|
// Hier erwarten wir eine echte Datei aus /public/CPL/
|
|
const scriptUrl = "/CPL?/CPL/SERVICE/digitalOutputs.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 digitalOutputs.js");
|
|
document.body.appendChild(script);
|
|
});
|
|
|
|
const win = window as any;
|
|
const state = win.win_da_state;
|
|
const labels = win.win_da_bezeichnung;
|
|
|
|
if (!Array.isArray(state)) {
|
|
console.warn("⚠️ win_da_state fehlt oder ist ungültig:", state);
|
|
return [];
|
|
}
|
|
|
|
return state.slice(0, 4).map((status: number, index: number) => ({
|
|
id: index + 1,
|
|
label:
|
|
Array.isArray(labels) && labels[index]
|
|
? labels[index]
|
|
: `Ausgang ${index + 1}`,
|
|
status: status === 1,
|
|
}));
|
|
}
|
|
|
|
console.warn(`⚠️ Unbekannter CPL-Modus: ${mode}`);
|
|
return [];
|
|
};
|