Digitale Eingänge funktioniert, PLatzhalter 80-83 und nicht 81-84
This commit is contained in:
43
components/main/einausgaenge/README.md
Normal file
43
components/main/einausgaenge/README.md
Normal file
@@ -0,0 +1,43 @@
|
||||
### 🧩 Datenfluss CPLv4.0 Digitale Eingänge
|
||||
|
||||
```mermaid
|
||||
classDiagram
|
||||
|
||||
class EmbeddedServer {
|
||||
+ Generiert de.js per CGI
|
||||
+ Ersetzt Platzhalter wie <%=DES81%>
|
||||
+ Kein Node.js vorhanden
|
||||
}
|
||||
|
||||
class DeJS {
|
||||
+ JavaScript mit konkreten Werten
|
||||
+ Beispiel: win_de_state, win_de_label
|
||||
}
|
||||
|
||||
class FrontendLoader {
|
||||
+ Lädt de.js dynamisch mit script-Tag
|
||||
+ Pfad: /CPL?/CPL/SERVICE/de.js
|
||||
}
|
||||
|
||||
class DatenMapper {
|
||||
+ Wandelt window-Variablen in Objekte
|
||||
+ Wandelt in strukturierte Eingangs-Daten
|
||||
}
|
||||
|
||||
class ReduxStore {
|
||||
+ digitalInputsSlice
|
||||
+ Speichert die Eingänge im State
|
||||
}
|
||||
|
||||
class ReactComponent {
|
||||
+ DigitalInputs.tsx
|
||||
+ useSelector: Zugriff auf Redux
|
||||
+ Darstellung mit Tailwind
|
||||
}
|
||||
|
||||
EmbeddedServer --> DeJS : erstellt per CGI
|
||||
DeJS --> FrontendLoader : wird per Script geladen
|
||||
FrontendLoader --> DatenMapper : verarbeitet window-Variablen
|
||||
DatenMapper --> ReduxStore : dispatch(setInputs)
|
||||
ReduxStore --> ReactComponent : useSelector() → Anzeige
|
||||
```
|
||||
Reference in New Issue
Block a user