- `selectedSlot` in `kueChartModeSlice.ts` hinzugefügt, um den aktiven Slot zu speichern. - `handleButtonClick.ts` aktualisiert, damit `selectedSlot` in Redux gesetzt wird. - `handleOpenChartModal.ts` angepasst, sodass `selectedSlot` beim Öffnen des Modals gesetzt wird. - `Kue705FO.tsx` nutzt jetzt Redux für die Slot- und Modus-Steuerung (`selectedSlot`, `activeMode`). - Redux-Logik optimiert: `selectedSlot` wird nun konsistent zwischen `TDRChart.tsx` und `ChartSwitcher.tsx` genutzt. - Verbesserung der Benutzererfahrung: Nur `onClick` verwendet, `onMouseOver` wegen Performance-Problemen vermieden. ✅ Jetzt wird der richtige Slot in Redux gespeichert, wenn ein Button oder das Chart-Modal geöffnet wird. ✅ `TDRChart.tsx` zeigt nur das gewählte Modul an, kein unnötiges Neuladen von Daten. ✅ Stabile und optimierte Chart-Steuerung ohne ungewollte Änderungen durch Mausbewegungen.
57 lines
1.5 KiB
TypeScript
57 lines
1.5 KiB
TypeScript
// /redux/slices/tdrChartSlice.ts
|
|
import { createSlice, PayloadAction } from "@reduxjs/toolkit";
|
|
import { fetchAllTDRChartData } from "../thunks/fetchAllTDRChartThunk";
|
|
|
|
interface TDRChartState {
|
|
data: any[];
|
|
selectedSlot: number | null;
|
|
selectedChartType: "TDR" | "Schleife";
|
|
loading: boolean;
|
|
error: string | null;
|
|
}
|
|
|
|
const initialState: TDRChartState = {
|
|
data: [],
|
|
selectedSlot: null,
|
|
selectedChartType: "TDR",
|
|
loading: false,
|
|
error: null,
|
|
};
|
|
|
|
const tdrChartSlice = createSlice({
|
|
name: "tdrChart",
|
|
initialState,
|
|
reducers: {
|
|
setSelectedSlot: (state, action: PayloadAction<number>) => {
|
|
state.selectedSlot = action.payload;
|
|
},
|
|
setSelectedChartType: (
|
|
state,
|
|
action: PayloadAction<"TDR" | "Schleife">
|
|
) => {
|
|
state.selectedChartType = action.payload;
|
|
},
|
|
},
|
|
extraReducers: (builder) => {
|
|
builder
|
|
.addCase(fetchAllTDRChartData.pending, (state) => {
|
|
state.loading = true;
|
|
state.error = null;
|
|
})
|
|
.addCase(
|
|
fetchAllTDRChartData.fulfilled,
|
|
(state, action: PayloadAction<any[]>) => {
|
|
state.loading = false;
|
|
state.data = action.payload;
|
|
}
|
|
)
|
|
.addCase(fetchAllTDRChartData.rejected, (state, action) => {
|
|
state.loading = false;
|
|
state.error = action.payload as string | null;
|
|
});
|
|
},
|
|
});
|
|
|
|
export const { setSelectedSlot, setSelectedChartType } = tdrChartSlice.actions;
|
|
export default tdrChartSlice.reducer;
|