feat: Digitale Ausgänge vollständig implementiert (Lesen & Schreiben in allen Modi)

- 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
This commit is contained in:
ISA
2025-06-19 09:01:49 +02:00
parent 1b01f37f90
commit dbb38cc7d8
17 changed files with 401 additions and 64 deletions

View File

@@ -1,10 +1,10 @@
// /services/fetchDigitalOutputsService.ts
// /services/fetchDigitalOutputsService.ts
export const fetchDigitalOutputsService = async () => {
const mode = process.env.NEXT_PUBLIC_CPL_MODE;
if (mode === "json") {
const res = await fetch("/api/cpl/digitalOutputsAPIHandler");
const res = await fetch("/api/cpl/getDigitalOutputsJsonHandler");
if (!res.ok)
throw new Error("❌ Fehler beim Laden der digitalen Ausgänge (JSON)");
@@ -12,6 +12,65 @@ export const fetchDigitalOutputsService = async () => {
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 [];
@@ -27,44 +86,6 @@ export const fetchDigitalOutputsService = async () => {
}));
}
// jsmock oder production
let scriptUrl = "";
if (mode === "production") {
scriptUrl = "/CPL?/CPL/SERVICE/digitalOutputs.js";
} else if (mode === "jsmock") {
scriptUrl = "/CPLmockData/SERVICE/digitalOutputsMockData.js";
} else {
console.warn(
`⚠️ fetchDigitalOutputsFromScript wird nur in 'jsmock' oder 'production' verwendet (aktueller Modus: ${mode})`
);
return [];
}
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 [];
};