Files
CPLv4.0/services/fetchDigitalInputsService.ts
ISA 14bd72756a feat: CGI-kompatiblen CSV-Parser für digitale Eingänge implementiert
- digitaleInputsMockData.json angepasst: CGI-nahe Simulation mit CSV-Strings und Stringwerten
- fetchDigitalInputsService.ts erweitert:
  - CSV-Zeilen werden automatisch in Arrays umgewandelt
  - Labels wie "'DE1','DE2'" werden korrekt aufgeteilt
  - Daten aus 4 CGI-Blöcken zu 32 Eingängen gemappt
- ermöglicht realitätsnahe Tests in Entwicklungsumgebung ohne Produktion
2025-07-09 08:41:50 +02:00

96 lines
2.7 KiB
TypeScript

export interface DigitalInput {
id: number;
value: number | string;
label: string;
invert: boolean;
counter: number | string;
timeFilter: number | string;
weighting: number | string;
counterActive: boolean;
eingangOffline: boolean;
status: boolean;
flutter: boolean;
zaehlerAktiv: boolean;
}
// 🧠 Neu: CSV-Zeile wie "1,0,1,0" in [1,0,1,0] konvertieren
const parseCsvNumbers = (line: string): number[] =>
line.split(",").map((v) => Number(v.trim()));
// 🧠 Neu: CSV-Zeile wie "'DE1','DE2'" in ["DE1", "DE2"] umwandeln
const parseCsvLabels = (line: string): string[] =>
line.split(",").map((v) => v.trim().replace(/^'+|'+$/g, ""));
export const fetchDigitalInputsService = async (): Promise<DigitalInput[]> => {
const mode = "production"; // ⛳ production oder json
const url =
mode === "production"
? "/CPL?/CPL/SERVICE/digitalInputs.json"
: "/api/cpl/getDigitalInputsHandler";
const res = await fetch(url);
if (!res.ok) {
throw new Error(`❌ Fehler beim Laden der digitalen Eingänge (${mode})`);
}
const data = await res.json();
// 🧠 Neu: CSV-Zeilen in Arrays umwandeln
const state = data.win_de_state.flatMap(parseCsvNumbers);
const label = data.win_de_label.flatMap(parseCsvLabels);
const invert = data.win_de_invert.flatMap(parseCsvNumbers);
const counter = data.win_de_counter.flatMap((line: string) =>
line.split(",").map((v) => v.trim())
);
const timeFilter = data.win_de_time_filter.flatMap((line: string) =>
line.split(",").map((v) => v.trim())
);
const weighting = data.win_de_weighting.flatMap((line: string) =>
line.split(",").map((v) => v.trim())
);
const counterActive = data.win_de_counter_active.flatMap(parseCsvNumbers);
const offline = data.win_de_offline.flatMap(parseCsvNumbers);
interface CsvData {
state: number[];
label: string[];
invert: number[];
counter: (number | string)[];
timeFilter: (number | string)[];
weighting: (number | string)[];
counterActive: number[];
offline: number[];
}
// Removed redundant DigitalInputResult interface
const csvData: CsvData = {
state,
label,
invert,
counter,
timeFilter,
weighting,
counterActive,
offline,
};
return csvData.state.map(
(_, i): DigitalInput => ({
id: i + 1,
value: csvData.state[i],
label: csvData.label[i],
invert: !!csvData.invert[i],
counter: csvData.counter[i],
timeFilter: csvData.timeFilter[i],
weighting: csvData.weighting[i],
counterActive: !!csvData.counterActive[i],
eingangOffline: !!csvData.offline[i],
status: !!csvData.state[i],
flutter: false,
zaehlerAktiv: false,
})
);
};