analoge eingänge
This commit is contained in:
97
redux/slices/analogInputsSlice.ts
Normal file
97
redux/slices/analogInputsSlice.ts
Normal file
@@ -0,0 +1,97 @@
|
||||
// Redux Slice: redux/slices/analogInputsSlice.ts
|
||||
import { createSlice, PayloadAction, createAsyncThunk } from "@reduxjs/toolkit";
|
||||
|
||||
export interface AnalogInput {
|
||||
id: number | null;
|
||||
value: number | null;
|
||||
name: string;
|
||||
uW: boolean;
|
||||
uG: boolean;
|
||||
oW: boolean;
|
||||
oG: boolean;
|
||||
}
|
||||
|
||||
export interface AnalogInputsState {
|
||||
[key: string]: AnalogInput;
|
||||
}
|
||||
|
||||
// Standardwerte für Eingänge
|
||||
const defaultAnalogInput: AnalogInput = {
|
||||
id: null,
|
||||
value: null,
|
||||
name: "",
|
||||
uW: false,
|
||||
uG: false,
|
||||
oW: false,
|
||||
oG: false,
|
||||
};
|
||||
|
||||
// Initialer Zustand
|
||||
const initialState: AnalogInputsState = {
|
||||
win_analogInputs1: { ...defaultAnalogInput },
|
||||
win_analogInputs2: { ...defaultAnalogInput },
|
||||
win_analogInputs3: { ...defaultAnalogInput },
|
||||
win_analogInputs4: { ...defaultAnalogInput },
|
||||
win_analogInputs5: { ...defaultAnalogInput },
|
||||
win_analogInputs6: { ...defaultAnalogInput },
|
||||
win_analogInputs7: { ...defaultAnalogInput },
|
||||
win_analogInputs8: { ...defaultAnalogInput },
|
||||
};
|
||||
|
||||
// Dynamisch Mock-Daten aus `window` abrufen
|
||||
export const loadFromWindow = createAsyncThunk(
|
||||
"analogInputs/loadFromWindow",
|
||||
async (_, { dispatch }) => {
|
||||
const data: Partial<AnalogInputsState> = {};
|
||||
|
||||
for (let i = 1; i <= 8; i++) {
|
||||
const key = `win_analogInputs${i}`;
|
||||
const value = (window as any)[key];
|
||||
|
||||
if (Array.isArray(value) && value.length === 7) {
|
||||
data[key] = {
|
||||
id: value[0],
|
||||
value: value[1],
|
||||
name: value[2],
|
||||
uW: value[3] === 1,
|
||||
uG: value[4] === 1,
|
||||
oW: value[5] === 1,
|
||||
oG: value[6] === 1,
|
||||
};
|
||||
}
|
||||
}
|
||||
|
||||
dispatch(setAnalogInputs(data)); // ✅ Redux direkt aktualisieren
|
||||
return data;
|
||||
}
|
||||
);
|
||||
|
||||
// Redux Slice
|
||||
const analogInputsSlice = createSlice({
|
||||
name: "analogInputsSlice",
|
||||
initialState,
|
||||
reducers: {
|
||||
setAnalogInput(
|
||||
state,
|
||||
action: PayloadAction<{ key: string; value: AnalogInput }>
|
||||
) {
|
||||
state[action.payload.key] = action.payload.value;
|
||||
},
|
||||
setAnalogInputs(state, action: PayloadAction<Partial<AnalogInputsState>>) {
|
||||
Object.entries(action.payload).forEach(([key, value]) => {
|
||||
if (value) {
|
||||
state[key] = value;
|
||||
}
|
||||
});
|
||||
},
|
||||
},
|
||||
extraReducers: (builder) => {
|
||||
builder.addCase(loadFromWindow.fulfilled, (state, action) => {
|
||||
Object.assign(state, action.payload);
|
||||
});
|
||||
},
|
||||
});
|
||||
|
||||
export const { setAnalogInput, setAnalogInputs } = analogInputsSlice.actions;
|
||||
|
||||
export default analogInputsSlice.reducer;
|
||||
Reference in New Issue
Block a user